yii中表单更新中的Ajax验证

时间:2012-09-18 13:30:02

标签: javascript yii

我有一个用于创建和编辑某些字段的表单。我在提交表单之前使用Ajax验证,如

 <?php $form=$this->beginWidget('CActiveForm', array(
            'id'=>'candidates-profiles-form',
            'enableAjaxValidation'=>true,
                        'enableClientValidation'=>true,
    'clientOptions'=>array(
        'validateOnSubmit'=>true,
        'validateOnChange'=>false,
         'beforeValidate'=>"js:function(form) {         
            if((form.data('submitObject')[0].id ) == 'cancel'){
            alert('cancalclicked');
                this.validateOnSubmit = false;
        this.validateOnChange = false;
        this.beforeValidate = ''; // the problem is caused by this line
        form.submit();
        return false;

                }
                else{
                  alert('submitclicked');
                return true;

                }

        }",    
        'afterValidate'=>"js:function(form, data, hasError) {
       if(hasError) {
                alert('We have detected some input errors and has not saved your data. Please click Ok to correct them.');
                return false;
            }
            else {          
                if(confirm('We have validated your input and we are ready to save your data. Please click Ok to save or Cancel to return to input.'))
                    return true;
                else
                    return false;
            }
        }",)


)); ?> 

创建之后它完全进入了AfterValidate函数并且工作正常。但是在编辑之后它并不是全部都在afterValidate之后。但是它会在之前提交并提交表格,而不是达到“死后”。

1 个答案:

答案 0 :(得分:0)

确保你有$ this-&gt; performAjaxValidation($ model);在你的控制器中进行该动作。