YII2.0使用ActiveForm表单(转)
Controller控制器层代码
- <?php
- namespace frontend\controllers;
- use frontend\models\UserForm;
- class UserController extends \yii\web\Controller
- {
- public function actionIndex()
- {
- $model = new UserForm;
- if ($model->load(\Yii::$app->request->post()) && $model->validate())
- {
- echo "通过";
- }
- return $this->render('index',[
- "model" => $model,
- ]);
- }
- }
VIEWS视图层代码
- <?php
- use yii\helpers\Html;
- use yii\widgets\ActiveForm;
- ?>
- <h1>YII2.0使用ActiveForm</h1>
- <?php $form = ActiveForm::begin([
- 'action' => ['log/login'], //提交地址(*可省略*)
- 'method'=>'post', //提交方法(*可省略默认POST*)
- 'id' => 'login-form', //设置ID属性
- 'options' => [
- 'class' => 'form-horizontal', //设置class属性
- 'enctype' => 'multipart/form-data' //文件上传时添加该编码
- ],
- 'fieldConfig' => [
- 'template' => '<div class="form-group"><center><label class="col-md-2 control-label" for="type-name-field">{label}</label></center><div class="col-md-8 controls">{input}{error}</div></div>'
- ], //设置模板的样式
- ]); ?>
- <!--文本框 (*验证长度可在这里写 maxlength 这样就不用再 model 里面写了 *)-->
- <?= $form->field($model, 'username',['inputOptions' => ['placeholder'=>'请输入用户名','class' => 'ipt'],'template'=>'<div class="form-group"><div class="col-md-8 controls">{label}{input}{error}</div></div>'])->textInput(['maxlength' => 20,"style"=>"width:200px; height:30px;"]) ?>
- <!--密码框 (*不使用他的lable只需要用false把他禁止, 然后你可以自己写*)-->
- <h4>密码</h4><?= $form->field($model, 'pwd')->label(false)->passwordInput(['maxlength' => 20,"style"=>"width:200px; height:30px;","placeholder"=>"请输入您的密码"]) ?>
- <?= $form->field($model, 're_pwd')->passwordInput(['maxlength' => 20,"style"=>"width:200px; height:30px;","placeholder"=>"请输入您的密码"]) ?>
- <!--单选按钮(*设置默认选中*)-->
- <?php $model->sex=1; echo $form->field($model, 'sex')->radioList(['1'=>'男','0'=>'女']) ?>
- <!--验证邮箱-->
- <?= $form->field($model, 'email')->textInput() ?>
- <!--下拉框的默认选中使用 prompt 设置 -->
- <?= $form->field($model, 'school')->dropDownList(['1'=>'大学','2'=>'高中','3'=>'初中'], ['prompt'=>'请选择','style'=>'width:120px']) ?>
- <!--文件上传-->
- <?= $form->field($model, 'photo')->fileInput() ?>
- <!--复选框 -->
- <?= $form->field($model, 'hobby')->checkboxList(['0'=>'篮球','1'=>'足球','2'=>'羽毛球','3'=>'乒乓球']) ?>
- <!--文本域-->
- <?= $form->field($model, 'remark')->textarea(['rows'=>3]) ?>
- <!--隐藏域-->
- <?= $form->field($model, 'userid')->hiddenInput(['value'=>3])->label(false); ?>
- <?= Html::submitButton('提交', ['class'=>'btn btn-primary','name' =>'submit-button']) ?>
- <?= Html::resetButton('重置', ['class'=>'btn btn-primary','name' =>'submit-button']) ?>
- <?php ActiveForm::end(); ?>
MODELS层表单验证
- <?php
- namespace frontend\models;
- use Yii;
- class UserForm extends \yii\db\ActiveRecord
- {
- /**
- *@param参数
- */
- public $username;
- public $pwd;
- public $re_pwd;
- public $email;
- public $bobby;
- public $remark;
- public $photo;
- public $school;
- public $info;
- /**
- * @inheritdoc
- */
- public static function tableName()
- {
- return '{{%user}}';
- }
- /**
- * @inheritdoc
- */
- public function rules()
- {
- return [
- //验证不能为空
- [['username', 'pwd', 'email', 'hobby'], 'required' ,"message"=>"{attribute}不能为空"],
- //验证用户唯一
- ['username', 'unique', 'targetClass' => '\frontend\models\User', 'message' => '用户名已存在.'],
- //验证密码不一致
- ['re_pwd', 'compare', 'compareAttribute' => 'pwd', 'message' => '两次密码不一致'],
- //验证字符串长度
- [['username'],"string", "max"=>"10", "min"=>"5", "tooLong"=>"{attribute}不能大于10个字符", "tooShort"=>"{attribute}不能小于5个字符"],
- //验证文件上传的格式
- ['photo','file',
- 'extensions'=>['jpg','png','gif'],'wrongExtension'=>'只能上传{extensions}类型文件!',
- 'maxSize'=>1024*1024*2, 'tooBig'=>'文件上传过大!',
- 'skipOnEmpty'=>false,'uploadRequired'=>'请上传文件!',
- 'message'=>'上传失败!'
- ]
- //采用rules 规则验证
- ['email', 'email',"message"=>"{attribute}格式错误"],
- //方法2:
- //正则验证 ['tel','match','pattern'=>'/^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})?$/','message'=>"{attribute}邮箱输入有误."],
- [['remark'], 'string', 'max' => 200],
- ];
- }
- /**
- * @inheritdoc
- */
- public function attributeLabels()
- {
- return [
- 'user_id' => '自增ID',
- 'username' => '用户名',
- 'pwd' => '密码',
- 're_pwd' => '请再次输入密码',
- 'sex' => '性别',
- 'photo' => '头像',
- 'email' => '邮箱',
- 'hobby' => '爱好',
- 'school' => '学校',
- 'remark' => '备注信息',
- ];
- }
- }
YII2.0使用ActiveForm表单(转)的更多相关文章
- yii2之ActiveForm表单使用
因目前项目并非前后端分离模式,且用到PHP的yii2框架(所有html代码,js较多内嵌在.php文件内多少采用同步提交[喷墨中...]),遂对于前端面上需要用到的yii2小组件一些整理(因是前端若涉 ...
- yii2 创建ActiveForm(表单)
表单的生成表单中的方法 ActiveForm::begin()方法 ActiveForm::end()方法 getClientOptions()方法 其它方法:errorSum ...
- yii中调整ActiveForm表单样式
Yii2中对于表单和字段的支持组件为ActiveForm和ActiveField, <?php $form = ActiveForm::begin([ 'id' => 'login-for ...
- <玩转Django2.0>读书笔记:表单
1. 表单字段 参考: 官方文档 Django表单字段汇总 2. 表单代码示例(forms.Form) # form.py代码 # 获取数据库数据 choices_list = [(i+1,v['ty ...
- 【Django笔记四】Django2.0中的表单
一.环境版本信息: 操作系统:windows10 Django版本:2.0.5 Python版本:3.6.4 Mysql版本: 5.5.53 安装mysql 二.基础信息 1.App中的模型mod ...
- thinkPHP5.0使用form表单提交数据和删除文章,不用TP的提示页面,使用弹出提示信息
form表单提交数据和删除文章时,TP的默认信息提示页面的看起来不是很好看,想要实现弹窗提示怎么做呢? 前端:可以使用前端的一个知识--iframe,iframe元素会创建包含另外一个文档的内联框架: ...
- yii2.0 Activeform表单部分组件使用方法
文本框:textInput(); 密码框:passwordInput(); 单选框:radio(),radioList(); 复选框:checkbox(),checkboxList(); 下拉框:dr ...
- yii2.0 Activeform表单部分组件使用方法 [ 2.0 版本 ]
文本框:textInput(); 密码框:passwordInput(); 单选框:radio(),radioList(); 复选框:checkbox(),checkboxList(); 下拉框:dr ...
- [moka同学笔记]yii2 activeForm 表单样式的修改(二)
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABAEAAANXCAIAAADLkdErAAAgAElEQVR4nOzdfWwc953nef6zwO5Zg8
随机推荐
- Space Ant
Space Ant The most exciting space discovery occurred at the end of the 20th century. In 1999, scient ...
- WebSphere禁用SSLv3和RC4算法教程
WebSphere经常会报“SSL 3.0 POODLE攻击信息泄露”和"SSL/TLS 受诫礼(BAR-MITZVAH)攻击"两个漏洞,前者建议禁用SSL算法后者建议禁用RC4算 ...
- std::string find 的返回值
std::string 的方法 find,返回值类型是std::string::size_type, 对应的是查找对象在字符串中的位置(从0开始), 如果未查找到,该返回值是一个很大的数据(4294 ...
- 1-2Controller之Session
laravel5.5版本. 视频教程是慕课网中的:轻松学会Laravel-表单篇 1-2 /*session简介: 1.由于HTTP协议是无状态(Stateless)的,所以session提供一种保存 ...
- Python格式化字符 %s %d %f
格式 描述%% 百分号标记 #就是输出一个%%c 字符及其ASCII码%s 字符串%d 有符号整数(十进制)%u 无符号整数(十进制)%o 无符号整数(八进制)%x 无符号整数(十六进制)%X 无符号 ...
- 玩linux就是不断的踩坑,踩坑。最近的坑。xpath firefox兼容问题,抓取表格。
最近在抓取一个页面表格时发现,用firefox提取的xpath,不能用,仔细分析后,发现是提取的xpath多了一个tbody标签.在xpath路径中删掉这段就好了. last_A5='/html/bo ...
- JDK(java se development kit)的构成
1.javac(Java compiler)编译器 通过命令行输入javac命令调用Java编译器,编译Java文件的过程中,javac会检查源程序是否符合Java的语法,没有语法 问题就会将.jav ...
- border_mode
如果border_mode选择为same,那么卷积操作的输入和输出尺寸会保持一致.如果选择valid,那卷积过后,尺寸会变小 # apply a 3x3 convolution with 64 out ...
- :状态模式:GumballMachine
#ifndef __STATE_H__ #define __STATE_H__ #include <iostream> #include<stdlib.h> using nam ...
- Android : iperf-2.0.4 网络测试工具
一.源码下载及交叉编译: 下载:https://pan.baidu.com/s/1i6NYDF3 //包含linux和windows上的可执行文件 1. 解压后获得perf-2.0.4源码.2. ...