Yii 表单验证规则---总结

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验证时就只验证usernameemailphone这三个字段了,不会影响验证码。

 

Number:数字验证,加上'integerOnly'=>true,表示只能是整数,maxmin分别表示最大最小值,tooBigtooSmall分别是超过最大值和低于最小值时的错误提示信息

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()前须要将复选框的值处理成字符串

相关文章
相关标签/搜索