PHP
发布时间:2019-11-12 发布网站:大佬教程 code.js-code.com
大佬教程收集整理的这篇文章主要介绍了yii2 modal弹窗之ActiveForm ajax表单异步验证,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
前面我们讲述了以及,本以为modal要告一段落可以开始新的话题了,但是实际问题往往超乎想像,这不modal弹窗提交的表单说是怎么验证的问题又出来了,又出来了!
首先撇开modal不谈,我们就yii2 ActiveForm如何以Ajax的方式提交表单做一个简单的说明,这也是我们今天主题的重点,modal确实没啥好说了。后面若是有我再把话改回来。
yii2中,ActiveForm默认做了客户端验证,但是表单的提交,却不是无刷新的。也就是常常看到的表单提交后页面会刷新。如果想要开启无刷新的模式,只需要在ActiveForm开始开启enableAjaxValidation即可,像下面这样
php;">
'form-id','enableAjaxValidation' => true,]
); ?>
注意哦,id和enableAjaxValidation一个都不能少。
接着看服务端的实现
load(Yii::$app->
request->post()))
{
Yii::$app->response->format = yii\web\Response::FORMAT_JSON;
if ($errors = \yii\widgets\ActiveForm::validate($model))
{
return $errors;
} else
{
if($model->save
(false))
{
return $this->redirect(['index']
);
}
}
}
return $this->render('create',[
'model' => $model,]
);
如此一来就简单的实现了yii2异步无刷新提交表单了!
其实下面说与不说已经不重要了,主要是写给一些懒人参考吧。聪明的人看了标题就应该明白了如何解决modal通过ActiveForm提交表单的问题。
为了兼容modal,注意我们说的是兼容而不是实现,我们对程序稍稍做了些改动,仅做参考。
load(Yii::$app->
request->post()))
{
if ($model->save())
{
if (Yii::$app->
request->isAja
X) {
Yii::$app->response->format = \yii\web\Response::FORMAT_JSON;
return ['
success' => true];
}
return $this->redirect(['index']
);
} else
{
if (Yii::$app->
request->isAja
X) {
Yii::$app->response->format = \yii\web\Response::FORMAT_JSON;
return \yii\widgets\ActiveForm::validate($model
);
}
}
}
if (Yii::$app->
request->isAja
X) {
return $this->renderAjax('create',]
);
} else
{
return $this->render('create',]
);
}
以上所述是小编给大家介绍的yii2 modal弹窗之ActiveForm ajax表单验证的相关知识,希望对大家有所帮助,如果大家想了解更多内容敬请关注菜鸟教程网站!
大佬总结
以上是大佬教程为你收集整理的yii2 modal弹窗之ActiveForm ajax表单异步验证全部内容,希望文章能够帮你解决yii2 modal弹窗之ActiveForm ajax表单异步验证所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。