当我试图阻止多次点击提交时,验证无效

时间:2016-09-08 07:06:31

标签: javascript php zend-framework2

我已使用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>

2 个答案:

答案 0 :(得分:1)

$(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);
            }

        });
    });

答案 1 :(得分:-1)

您正在使用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" />

请注意,该按钮不是“提交”类型,而是普通按钮。有了这个,您可以创建一个javascript函数(“checkform()”)来检查输入是否有效。 javascript中有一个函数可以返回带有'required'html5属性的输入是否有效。这个功能是:

inputElement.checkValidity()

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