扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
小编给大家分享一下Yii框架如何实现表单提交验证功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
创新互联公司是一家专业提供宝鸡企业网站建设,专注与网站制作、成都网站设计、HTML5、小程序制作等业务。10年已为宝鸡众多企业、政府机构等服务。创新互联专业网站设计公司优惠进行中。具体如下:
一、前端提交的三种方式
前面已经提出,表单提交一共只有三种方式。
1. 前端原生html
(1)原生html标签
首先,直接使用html标签的input,a等;
其次,使用css进行布局。
再次,使用js或jquery方式验证
最后,提交(get/post/ajax,目前较多使用jquery提交)。
注:该种方式由于较灵活,使用最多。
(2)原生form
js或jquery方式验证,yii方式提交。
相对灵活
批注:如果仅仅使用表单自带的onsubmit验证不够,也可以采用第一种办法。此时就不要使用form自带的submit按钮了。
2,前端使用yii自带widget
(3)yii方式验证、提交。
① 自带blog登陆表单
beginWidget('CActiveForm', array( 'id'=>'login-form', 'enableClientValidation'=>true, 'clientOptions'=>array( 'validateOnSubmit'=>true, ), )); ?>
② 上传用户头像时
beginWidget('CActiveForm', array( 'id'=>'user-form', 'enableAjaxValidation'=>false, 'htmlOptions'=>array('enctype'=>'multipart/form-data'), )); ?>
③ 看到的一个例子
beginWidget('CActiveForm',array( 'id'=>'login-from', 'enableAjaxValidation'=>true, 'action'=>'array('site/login'), ) ) ?>
此时用到yii的表单验证功能。需要model+controller+view配合使用。详见:yii指南。
Yii方式验证、提交
① 首先,在model的rules(){return array();}设置验证规则
② 其次,在view里使用errorMessage,label,field,error
labelEx($model,'author'); ?> textField($model,'author',array('size'=>60,'maxlength'=>128)); ?> error($model,'author'); ?>
3,最后,在controller里
使用
$model = new Post; $model->attributes=$_POST['Post'];
yii判断提交方式
Yii::app()->request->isPostRequest
效率比较:
(1)效率最差;
(2)效率中等;
(3)效率高。
二、Yii在后端接收前端传来值的两种方式
1,通过二维数组$_POST['ClassName']
如果前端的表单是关于某一个model的,可以用此方法。使用较多。
例如:
$model->attributes=$_POST['Post']; $comment->attributes=$_POST['Comment'];
还可以添加:
$comment->post_id=$this->id;
强制数据提交
$model->save(false)
2,获取get或post请求的值$this->request->getParam('key');
(1)form表单提交
前端:
后端:
$this->request->getParam('belongs_to');
(2)jquery的post提交
$this->request->getParam('key1');
以上是“Yii框架如何实现表单提交验证功能”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流