十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
这篇文章主要介绍“yii框架表单模型使用及以数组形式提交表单数据的方法教程”,在日常操作中,相信很多人在yii框架表单模型使用及以数组形式提交表单数据的方法教程问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”yii框架表单模型使用及以数组形式提交表单数据的方法教程”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
十余年的平桂网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都全网营销推广的优势是能够根据用户设备显示端的尺寸不同,自动调整平桂建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联从事“平桂网站设计”,“平桂网站推广”以来,每个客户项目都认真落实执行。按Yii文档里的描述,Yii在处理表单的一般过程是:
创建表单对应的模型类,设置字段验证规则
创建表单提交对应的action,处理提交的内容
在视图中创建表单form
在刚刚的一个小项目里,想使用ajax提交表单信息并验证保存,又不想用隐藏iframe来做无刷新提交,并且action中能够用到模型类的校验方法,就想到使用表单数组提交的方式,举个例子:
form代码:
复制代码 代码如下:
提交后可以直接使用 $_POST['arr'] 来获取提交的数据,$_POST['arr'] 为:
复制代码 代码如下:
Array
(
[0] => a
[1] => b
[2] => c
)
同理,如果使用以下form提交:
复制代码 代码如下:
Array
(
[3] => a
[6] => b
[8] => c
)
当然也能提交二维数组:
复制代码 代码如下:
Array
(
[0] => Array
(
[name1] => a
)
[1] => Array
(
[name2] => b
)
[2] => Array
(
[name3] => c
)
)
这里有一个问题,如果不设置第一个子数组的key,在生成数组时会将每个值顺序在arr中添加,如果想将信息保存在一个array中,添加一个key值即可,如下:
复制代码 代码如下:
Array
(
[a] => Array
(
[name1] => a1
[value1] => a2
)
[b] => Array
(
[name2] => b1
[value2] => b2
)
)
下面贴一下用ajax提交表单并且用yii表单模型验证的示例,首先是模型类部分,只有最简单的校验方法:
复制代码 代码如下:
class LandingForm extends CFormModel
{
public $landing_title;
public $landing_content;
public $landing_position;
public function rules()
{
return array(
array('landing_title, landing_content', 'required'),
array('landing_position', 'default', 'value'=>''),
);
}
}
发现个比较有意思的,就是模型类在设置参数校验的方法时,需要对每一个public参数都设置规则,如果有未设置规则的参数,在用$_POST中的表单值为模型赋值后,未设置规则的参数值将为空
action中获取表单提交的参数并且校验:
复制代码 代码如下:
$model = new LandingForm;
$model->attributes = $_POST['form'];
if($model->validate()){
$info = $model->attributes;
...
}
最后是前端提交表单部分的代码,用的jquery:
复制代码 代码如下:
var info = new Object();
info = { 'form[landing_title]': landing_title,
'form[landing_content]': landing_content,
'form[landing_position]': landing_position,
};
var url = "...";
$.post(url, info, function(rst){
...
});
到此,关于“yii框架表单模型使用及以数组形式提交表单数据的方法教程”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!