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


    Filter: 过滤,'filter'=>'trim',表示去空格

    Required:必须的,表示不能为空

    Match: 匹配正则,需要和pattern一起使用,定义正则表达式,'pattern'=>'/^w{6,20}$/',

    Unique:验证数据唯一性,在注册时用到的比较多,这里需要注意的是,在rules规则里面定义的唯一性验证,只有在服务器端才能验证,如果想要在表单页面显示,需要开启”enableAjaxValidation”=>ture;

    例如:

        <?php $form = ActiveForm::begin([

               'id'=>'sign-form',

               //'enableAjaxValidation' => true,//启用ajax验证,将属性值发送到服务器端进行验证并返回结果,默认为false

               'enableClientValidation' => true,//启用客户端验证,默认值为true,关闭后表单无js验证

               'options'=>['action'=>'usermessage/signform', 'method'=>'post', 'enctype'=>'multipart/form-data']]); ?>

     这里需要注意的是,在这里启用的话,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 = yiiwebResponse::FORMAT_JSON;

                    return yiiootstrapActiveForm::validate($model);

                }

    在有数据提交时,最好先执行$model->load(Yii::$app->request->post()); 操作,不要做多余的处理,然后判断ajax,否则ajax验证的时候可能会报错500。如果有验证码,这里就会有另一个问题:return yiiootstrapActiveForm::validate($model);这个验证的是所有的属性,而验证码执行validate后就会重新生成,那么在表单提交时我们进行数据有效性验证时就会报错,解决方式:yiiootstrapActiveForm::validate()这个方法其实是有两个参数的,$model,$attributes,我们可以指定ajax验证某一些特定的属性,写法是:yiiootstrapActiveForm::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' => 'yiicaptchaCaptchaAction',

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

  • 相关阅读:
    867-转置矩阵
    704-二分查找
    选择排序
    999-车的可用捕获量
    66-加一
    观察者模式(1)
    命令模式(3)-宏命令
    命令模式(2)-命令接口中的撤销方法
    接口测试
    移动端测试
  • 原文地址:https://www.cnblogs.com/bluealine/p/5341115.html
Copyright © 2020-2023  润新知