当我试图阻止多次点击提交时验证不起作用

validation not working when i am trying to prevent multiple click on submit

我已经使用 class='required' 进行必要的验证,当我删除 onClick="this.form.submit(); this.disabled=true; 时它工作正常 从提交按钮。 我想通过验证禁用多次点击

<form action="<?php echo $this->url('weeklyplan', array('action' => 'add')); ?>" method="post" id='myform'>
    <div class="mainformdiv">
        <div class= "formelementblock">
            <div class="formelement">
                <select name="txtdefined_week_id" id="txtdefined_week_id" class="select-block required"  onchange="showdateranges()">
                    <option value="">Select Defined Week</option>
                    <?php foreach ($definedweeks as $obj) { ?>
                        <option value="<?php echo $obj->defined_week_id; ?>"><?php echo $obj->start_day . "-" . $obj->end_day; ?></option>
                    <?php } ?>
                </select>
            </div>
        </div>

        <div class= "formelementblock">
            <div class="formelement">
                <input type="text"  readonly="readonly" name="txtstart_date" class="input-text datepickerwidth required" id="txtstart_date" placeholder="Start Date*"/>
            </div>

        </div>
        <div class= "formelementblock last">
            <div class="formelement">
                <input type="text" readonly="readonly"  name="txtend_date" class="input-text datepickerwidth required" id="txtend_date"  placeholder="End Date*"/>
            </div>
        </div>
    </div>

    <div class="clear"></div>
    <div class="form-button">
        <div class="button-block">
            <input onClick="this.form.submit(); this.disabled=true;" class="button" type="submit" name="button" id="button" value="Save" />&nbsp;&nbsp;&nbsp;
            <input class="button" type="button" name="button" id="button" value="Cancel" onclick="window.location = '<?php echo $this->url('weeklyplan', array('action' => 'index')); ?>'" />
        </div>
    </div>
</form>

您正在使用 html5 表单验证。如果您想在提交前检查输入是否有效,您必须更改:

<input onClick="this.form.submit(); this.disabled=true;" class="button" type="submit" name="button" id="button" value="Save" />

类似于:

<input onClick="checkform(); this.disabled=true;" class="button" type="button" name="button" id="button" value="Save" />

请注意,该按钮不是 'submit' 类型,而是普通按钮。有了它,您可以创建一个 javascript 函数 ("checkform()") 来检查输入是否有效。 javascript中有一个函数是returns一个输入'required'html5属性是否有效。这个函数是:

inputElement.checkValidity()

检查所有输入是否有效后,您可以提交表单。

$(document).ready(function() {
        $("#button").click(function(){
            $('#button').attr('disabled',true);
            $('#myform').submit();
            var no=$("#myform").validate().toShow.length;
            if(no!=0){
                $('#button').attr('disabled',false);
            }

        });
    });