我在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中进行处理。
我在网上搜索了这个并尝试了所有建议,但都没有。
谢谢大家!
答案 0 :(得分:1)
我通过添加'afterValidate'=>'js:function(form,data,hasError){ send(form,data,hasError);
并删除'onsubmit'=>"return send();"
行来解决问题。现在它显示验证错误,只保存模型一次。
查看this post了解详情。