在Yii

时间:2015-05-28 15:11:22

标签: javascript php ajax validation yii

我在Yii中有一个由AJAX提交的以下简单表格:

<?php $form = $this->beginWidget('CActiveForm', array(
        'id' => 'application-form',
        'enableAjaxValidation' => true,
        'enableClientValidation' => true,
        'htmlOptions' => array(
            'enctype' => 'multipart/form-data',
            'onsubmit'=>"return send();"
        ),
        'clientOptions'=>array('validateOnSubmit'=>true)

)); ?>
<div class="row">
        <?php echo $form->labelEx($model, 'name'); ?>
        <?php echo $form->textField($model, 'name', array('size' => 60,'maxlength' => 255)); ?>
        <?php echo $form->error($model, 'name'); ?>
    </div>
<div class="row buttons">
        <?php echo CHtml::submitButton($model->isNewRecord ? 'Create' : 'Save'); ?>
    </div>

提交功能:

function send (){

var data_form=$("#application-form").serialize();

$.ajax({
    type: "POST",
    url: "<?php echo Yii::app()->createUrl('admin/application/create') ?>",
    dataType:'json',
    data: data_form,
    success: function (data, textStatus, jqXHR) {
        console.log(data);
        alert("success",textStatus);
    },
    error: function (jqXHR, textStatus, errorThrown) {
       // console.log( errorThrown);

    }
});
return false;
}

我的创建控制器:

public function actionCreate()
    {
        $model = new Application;
        $model->setScenario('create');

       $this->performAjaxValidation($model);

        if (isset($_POST['Application'])) {

           if ( $model->save()){

                echo CJSON::encode(array('success' => 'true','id'=>$model->id));
                Yii::app()->end();
            }
        }

        $this->render('create', array(
            'model' => $model
        ));
    }

提交的名称是必需的,现在只是验证。当我尝试提交没有输入字段名称的表单时,验证消息会在Yii中显示。但是当我正确填写表格时,我的模型在数据库中输入两次。如果我删除以下属性:

'clientOptions'=>array('validateOnSubmit'=>true)

模型正确保存(仅一次),但不显示验证消息。

当我通过ajax提交表单并且模型不能保存两次时,如何在Yii中显示默认验证消息。我需要以这种方式提交表单,因为我将在Ajax响应中返回模型id以便在JavaScript中进行处理。

我在网上搜索了这个并尝试了所有建议,但都没有。

谢谢大家!

1 个答案:

答案 0 :(得分:1)

我通过添加'afterValidate'=>'js:function(form,data,hasError){ send(form,data,hasError);并删除'onsubmit'=>"return send();"行来解决问题。现在它显示验证错误,只保存模型一次。

查看this post了解详情。