`
zccst
  • 浏览: 3296085 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Yii与表单交互的三种方式

 
阅读更多
作者:zccst

一、前端提交的三种方式
前面已经提出,表单提交一共只有三种方式。

1,前端原生html
(1)原生html标签
首先,直接使用html标签的input,a等;
其次,使用css进行布局。
再次,使用js或jquery方式验证
最后,提交(get/post/ajax,目前较多使用jquery提交)。

注:该种方式由于较灵活,使用最多。


(2)原生form
js或jquery方式验证,yii方式提交。
相对灵活
<form ... onSubmit="return validationFunc">
...
</form>
<script type="text/javascript">
function validationFunc(){
    //验证逻辑
}
</script>


批注:如果仅仅使用表单自带的onsubmit验证不够,也可以采用第一种办法。此时就不要使用form自带的submit按钮了。


2,前端使用yii自带widget
(3)yii方式验证、提交。
//1,自带blog登陆表单
<?php 
		$form=$this->beginWidget('CActiveForm', array(
			'id'=>'login-form',
			'enableClientValidation'=>true,
			'clientOptions'=>array(
				'validateOnSubmit'=>true,
			),
		));
	?>

//2,上传用户头像时
<?php $form=$this->beginWidget('CActiveForm', array(
	'id'=>'user-form',
	'enableAjaxValidation'=>false,
	'htmlOptions'=>array('enctype'=>'multipart/form-data'),
)); ?>

//3,看到的一个例子
<?php $form=$this->beginWidget('CActiveForm',array(
	'id'=>'login-from',
	'enableAjaxValidation'=>true,
	'action'=>'array('site/login'),
	)
)
?>


此时用到yii的表单验证功能。需要model+controller+view配合使用。详见:yii指南。
Yii方式验证、提交
1,首先,在model的rules(){return array();}设置验证规则

2,其次,在view里使用errorMessage,label,field,error
<?php echo $form->labelEx($model,'author'); ?>
<?php echo $form->textField($model,'author',array('size'=>60,'maxlength'=>128)); ?>
<?php echo $form->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;

2,获取get或post请求的值$this->request->getParam('key');
(1)form表单提交
前端:
<form>
<input type="text" name="belongs_to" />
<input type="submit" value="提交" />
</form>

后端:
$this->request->getParam('belongs_to');

(2)jquery的post提交
$this->request->getParam('key1');




如果您觉得本文的内容对您的学习有所帮助,您可以微信:


分享到:
评论

相关推荐

    yii2 创建表单 笔记

    yii2 创建表单 笔记

    Yii框架表单提交验证功能分析

    前面已经提出,表单提交一共只有三种方式。 1. 前端原生html (1)原生html标签 首先,直接使用html标签的input,a等; 其次,使用css进行布局。 再次,使用js或jquery方式验证 最后,提交(get/post/ajax,目前较多...

    yii框架yii框架yii框架yii框架yii框架

    很好用yii框架很好用yii框架很好用yii框架很好用yii框架很好用yii框架很好用yii框架很好用yii框架很好用yii框架很好用yii框架很好用yii框架很好用yii框架很好用yii框架很好用yii框架

    Yii框架表单模型和验证用法

    主要介绍了Yii框架表单模型和验证用法,结合实例形式分析了Yii表单模型的原理及验证器的使用技巧,需要的朋友可以参考下

    yii框架表单模型使用及以数组形式提交表单数据示例

    按Yii文档里的描述,Yii在处理表单的一般过程是: 创建表单对应的模型类,设置字段验证规则创建表单提交对应的action,处理提交的内容在视图中创建表单form在刚刚的一个小项目里,想使用ajax提交表单信息并验证保存...

    Yii框架form表单用法实例

    主要介绍了Yii框架form表单用法,实例分析了Yii中form表单的实现方法与相关技巧,非常具有实用价值,需要的朋友可以参考下

    深入理解Yii2.0

    采用的方式是分析框架的源代码,尝试从根上进行理解和阐述,并融入个人使用Yii开发的一些经验和教训。 通过本书,你将不仅仅了解到Yii怎么使用的实操技巧,还将掌握其实现的技术原理和内幕。 更为重要的是,接触...

    YII多种缓存机制

    YII 多种缓存机制的运用 如文件缓存内存缓存 动态缓存等

    基于YII2的中文验证码

    * 支持AJAX与普通表单方式,AJAX方式可以在浏览器端进行验证码正确判断 * 支持 数字、字母、算术、汉字、成语等8种类型验证码 * 支持 包含YII2原始风格,总共4种风格 * 目前版本不支持imagick方式,但留有相关...

    YII框架数据验证规则

    YII框架数据验证规则,各种详情的资料都在里面,yii最新表单验证规则

    yii用户注册表单验证实例

    主要介绍了yii用户注册表单验证,以实例形式详细分析了基于yii框架的用户注册表单验证功能模型,视图及控制器层具体实现技巧,需要的朋友可以参考下

    yii 表单设计

    知道yii的表单是怎样生成的吗,这里就有你想要答案!

    yii2swoole让yii2运行在swoole上

    yii2 swoole:让yii2运行在swoole上 , 运行在swoole上的yii2是运行在php-fpm上yii2的5倍以上

    yii framework(Yii)框架window版

    Yii采用严格的OOP编写,并有着完善的库引用以及全面的教程。从 MVC,DAO/ActiveRecord,widgets,caching,等级式RBAC,Web服务,到主题化,I18N和L10N,Yii提供了今日Web 2.0应用开发所需要的几乎一切功能。事实上...

    Yii 中文帮助文档

    它从一开始就为严谨的 Web 应用开发而精心设计,不是某个项目的副产品或第三方代码的组合,而是融合了作者丰富的 Web 应用开发经验和其它热门 Web 编程框架(或应用)优秀思想的结晶。 $Id: quickstart.what

    Yii2.0打造京东商城平台PHP电商实战Yii2.0视频教程

    Yii2.0级基于Yii1.X完全重写的,不仅是小版本升级的升级。所以想要系统学习Yii2.0这个框架这套教程可以从实战项目带你入手。不错的学习YII框架的基础课程,电商系统的结构完整、框架资源太大,传百度网盘了,链接在...

    Yii中表单用法实例详解

    本文实例讲述了Yii中表单用法。分享给大家供大家参考,具体如下: ...取决于使用用户所输入数据的方式,我们可以创建两种类型的模型。如果用户输入被收集、使用然后丢弃,我们应该创建一个表单模型; 如果用户

    yii框架中文手册教程和YII模板

    yii框架中文手册教程和YII模板 我很辛苦才找到的

    yii2-shell:交互式shell

    Yii 2的交互式Shell扩展 该扩展为基于提供了一个交互式shell。 有关许可证信息,请检查文件。 安装 安装此扩展的首选方法是通过 。 无论运行 composer require yiisoft/yii2-shell 或添加 " yiisoft/yii2-shell " ...

    yii1.1.10 开发包(包含yii权威指南以及yii博客例子讲解)

    yii1.1.10 开发包(包含yii权威指南以及yii博客例子讲解)

Global site tag (gtag.js) - Google Analytics