Filter: 过滤,'filter'=>'trim',表示去空格php
Required:必须的,表示不能为空ios
Match: 匹配正则,须要和pattern一块儿使用,定义正则表达式,'pattern'=>'/^\w{6,20}$/',web
Unique:验证数据惟一性,在注册时用到的比较多,这里须要注意的是,在rules规则里面定义的惟一性验证,只有在服务器端才能验证,若是想要在表单页面显示,须要开启”enableAjaxValidation”=>ture;ajax
例如:正则表达式
<?php $form = ActiveForm::begin([bootstrap
'id'=>'sign-form',数组
//'enableAjaxValidation' => true,//启用ajax验证,将属性值发送到服务器端进行验证并返回结果,默认为false服务器
'enableClientValidation' => true,//启用客户端验证,默认值为true,关闭后表单无js验证app
'options'=>['action'=>'usermessage/signform', 'method'=>'post', 'enctype'=>'multipart/form-data']]); ?>yii
这里须要注意的是,在这里启用的话,ajax验证是做用于全部的属性的,因此,还有另外一种开启方式,在某一个field里面开启
例如:<?= $form->field($model, 'username', ['enableAjaxValidation'=>true])->textInput() ?>,这样就单独做用于username属性了。
要想实现表单ajax验证惟一性,后台还要一个ajax判断:把如下代码复制到控制器实例化模型层的下边
$model->load(Yii::$app->request->post());
if (Yii::$app->request->isAjax)
{
Yii::$app->response->format = \yii\web\Response::FORMAT_JSON;
return \yii\bootstrap\ActiveForm::validate($model);
}
在有数据提交时,最好先执行$model->load(Yii::$app->request->post()); 操做,不要作多余的处理,而后判断ajax,不然ajax验证的时候可能会报错500。若是有验证码,这里就会有另外一个问题:return \yii\bootstrap\ActiveForm::validate($model);这个验证的是全部的属性,而验证码执行validate后就会从新生成,那么在表单提交时咱们进行数据有效性验证时就会报错,解决方式:\yii\bootstrap\ActiveForm::validate()这个方法实际上是有两个参数的,$model,$attributes,咱们能够指定ajax验证某一些特定的属性,写法是:\yii\bootstrap\ActiveForm::validate($model, ['username', 'email', 'phone']);这样ajax验证时就只验证username,email,phone这三个字段了,不会影响验证码。
Number:数字验证,加上'integerOnly'=>true,表示只能是整数,max,min分别表示最大最小值,tooBig和tooSmall分别是超过最大值和低于最小值时的错误提示信息
Compare:比较,用于两个属性之间的比较,'compareAttribute'=>'password',表示与password比较
In:和range连用,定义范围,表示属性值必须在这个范围内,一般用于验证某些固定值
Email:邮箱验证
File:文件验证 extensions能够定义上传文件的类型
Captcha:验证码验证,须要定义生成验证码的方法,'captchaAction'=>'usermessage/captcha',usermessage表示控制器名,captcha表示方法名
能够在控制器层定义一个actions方法添加captcha方法:
/**
* 生成验证码的方法
*/
public function actions() {
parent::actions();
return [
'captcha' => [
'class' => 'yii\captcha\CaptchaAction',
//'fixedVerifyCode' => YII_ENV_TEST ? 'testme' : null,
'maxLength' => 3,
'minLength' => 3
],
];
}
每个验证均可以添加应用场景:’on’=>’register’;
在控制器层实例化模型层
$model = new Usermessage();
$model->setScenario('register'); 定义使用应用场景为register
在模型层须要定义场景做用的对象
/**
* 定义验证场景
*/
public function scenarios()
{
return [
'register' => ['username', 'password', 'repassword', 'age', 'sex', 'phone','email'],
'login' => ['username', 'password','age', 'sex', 'phone','email'],
];
}
而后在对应的验证规则后面限定应用场景’on’=>’register’;
当表单验证时,为在做用场景之内的参数能够不受验证规则的限制
添加入库:复选框因提交过来后是一个数组,因此在执行save()前须要将复选框的值处理成字符串