yii2 modal弹窗之ActiveForm ajax表单异步验证


Posted in PHP onJune 13, 2016

前面我们讲述了yii2中如何使用modal以及yii2 gridview列表内更新操作如何使用modal的问题,本以为modal要告一段落可以开始新的话题了,但是实际问题往往超乎想像,这不modal弹窗提交的表单说是怎么验证的问题又出来了,又出来了!

首先撇开modal不谈,我们就yii2 ActiveForm如何以Ajax的方式提交表单做一个简单的说明,这也是我们今天主题的重点,modal确实没啥好说了。后面若是有我再把话改回来。

yii2中,ActiveForm默认做了客户端验证,但是表单的提交,却不是无刷新的。也就是常常看到的表单提交后页面会刷新。如果想要开启无刷新的模式,只需要在ActiveForm开始开启enableAjaxValidation即可,像下面这样

<?php $form = ActiveForm::begin([
'id' => 'form-id',
'enableAjaxValidation' => true,
]
); ?>

注意哦,id和enableAjaxValidation一个都不能少。

接着看服务端的实现

if ($model->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,注意我们说的是兼容而不是实现,我们对程序稍稍做了些改动,仅做参考。

if ($model->load(Yii::$app->request->post())) {
if ($model->save()) { 
if (Yii::$app->request->isAjax) {
Yii::$app->response->format = \yii\web\Response::FORMAT_JSON;
return ['success' => true];
}
return $this->redirect(['index']);
} else {
if (Yii::$app->request->isAjax) {
Yii::$app->response->format = \yii\web\Response::FORMAT_JSON;
return \yii\widgets\ActiveForm::validate($model);
}
}
}
if (Yii::$app->request->isAjax) {
return $this->renderAjax('create', [
'model' => $model,
]);
} else {
return $this->render('create', [
'model' => $model,
]);
}

以上所述是小编给大家介绍的yii2 modal弹窗之ActiveForm ajax表单验证的相关知识,希望对大家有所帮助,如果大家想了解更多内容敬请关注三水点靠木网站!

PHP 相关文章推荐
随时给自己贴的图片加文字的php代码
Mar 08 PHP
php htmlentities和htmlspecialchars 的区别
Aug 18 PHP
ajax+php打造进度条代码[readyState各状态说明]
Apr 12 PHP
centos 5.6 升级php到5.3的方法
May 14 PHP
PHP中call_user_func_array()函数的用法演示
Feb 05 PHP
ThinkPHP之N方法实例详解
Jun 20 PHP
PHP+jQuery 注册模块的改进(一):验证码存入SESSION
Oct 14 PHP
一波PHP中cURL库的常见用法代码示例
May 06 PHP
解决微信授权回调页面域名只能设置一个的问题
Dec 11 PHP
老生常谈php中传统验证与thinkphp框架(必看篇)
Jun 10 PHP
php接口实现拖拽排序功能
Apr 23 PHP
php实现根据身份证获取精准年龄
Feb 26 PHP
Windows下PHP开发环境搭建教程(Apache+PHP+MySQL)
Jun 13 #PHP
PHPStorm+XDebug进行调试图文教程
Jun 13 #PHP
图文详解phpstorm配置Xdebug进行调试PHP教程
Jun 13 #PHP
PHP生成制作验证码的简单实例
Jun 12 #PHP
php gd等比例缩放压缩图片函数
Jun 12 #PHP
详解PHP中cookie和session的区别及cookie和session用法小结
Jun 12 #PHP
yii2中结合gridview如何使用modal弹窗实例代码详解
Jun 12 #PHP
You might like
php中对2个数组相加的函数
2011/06/24 PHP
关于laravel模板中生成URL的几种模式总结
2019/10/18 PHP
Nigma vs Alliance BO5 第三场2.14
2021/03/10 DOTA
jquery validator 插件增加日期比较方法
2010/02/21 Javascript
Javascript表格翻页效果的具体实现
2013/10/05 Javascript
当达到输入长度时表单自动切换焦点
2014/04/06 Javascript
javascript中的nextSibling使用陷(da)阱(keng)
2014/05/05 Javascript
JS实现生成会变大变小的圆环实例
2015/08/05 Javascript
js检测iframe是否加载完成的方法
2015/11/26 Javascript
深入理解JavaScript中的并行处理
2016/09/22 Javascript
jQuery实现页面顶部下拉广告
2016/12/30 Javascript
超全面的vue.js使用总结
2017/02/12 Javascript
Nodejs搭建wss服务器教程
2017/05/24 NodeJs
详解swiper在vue中的应用(以3.0为例)
2018/09/20 Javascript
vue radio单选框,获取当前项(每一项)的value值操作
2020/09/10 Javascript
[46:09]2014 DOTA2华西杯精英邀请赛 5 25 LGD VS VG第三场
2014/05/26 DOTA
[45:44]完美世界DOTA2联赛PWL S2 FTD vs PXG 第一场 11.27
2020/12/01 DOTA
Python实例之wxpython中Frame使用方法
2014/06/09 Python
Python实现115网盘自动下载的方法
2014/09/30 Python
Python中死锁的形成示例及死锁情况的防止
2016/06/14 Python
Python实现快速排序算法及去重的快速排序的简单示例
2016/06/26 Python
python实现本地图片转存并重命名的示例代码
2018/10/27 Python
Python大数据之使用lxml库解析html网页文件示例
2019/11/16 Python
keras实现多种分类网络的方式
2020/06/11 Python
使用keras时input_shape的维度表示问题说明
2020/06/29 Python
Python高并发解决方案实现过程详解
2020/07/31 Python
Ubuntu配置Pytorch on Graph (PoG)环境过程图解
2020/11/19 Python
美国最大的宠物药店:1-800-PetMeds
2016/10/02 全球购物
优纳科技软件测试面试题
2012/05/15 面试题
大一军训感言
2014/01/09 职场文书
测绘专业大学生职业生涯规划书
2014/02/10 职场文书
《陈涉世家》教学反思
2014/04/12 职场文书
2014国庆节商场促销活动策划方案
2014/09/16 职场文书
爱国主义电影观后感
2015/06/18 职场文书
2015年幼师个人工作总结
2015/10/15 职场文书
Linux磁盘管理方法介绍
2022/06/01 Servers