yii2-表单验证的一些规则

Rules验证规则:

required : 必须值验证属性||CRequiredValidator 的别名, 确保了特性不为空.

[['字段名1','字段名2'],required]    //字段1 2 必填

[['字段名'],required,'requiredValue'=>'必填值','message'=>'提示信息'];

email : 邮箱验证||CEmailValidator 的别名,确保了特性的值是一个有效的电邮地址.

['email', 'email'];

match : 正则验证||CRegularExpressionValidator 的别名, 确保了特性匹配一个正则表达式.

[['字段名'],'match','pattern'=>'正则表达式','message'=>'提示信息'];      
[['字段名'],'match','not'=>ture,'pattern'=>'正则表达式','message'=>'提示信息'];  /*正则取反*/

url : 网址||CUrlValidator 的别名, 确保了特性是一个有效的路径.

['website', 'url', 'defaultScheme' => 'http'];

captcha(验证码)||CCaptchaValidator 的别名,确保了特性的值等于 CAPTCHA 显示出来的验证码.

['verificationCode', 'captcha'];

safe : 安全

['description', 'safe'];

compare :(比较) CCompareValidator 的别名, 确保了特性的值等于另一个特性或常量.

['repassword', 'compare', 'compareAttribute' => 'password','message'=>'两次输入的密码不一致!'],

//compareValue:比较常量值 operator:比较操作符

['age', 'compare', 'compareValue' => 30, 'operator' => '>='];

default : 默认值||CDefaultValueValidator 的别名, 为特性指派了一个默认值.

['age', 'default', 'value' => null];

exist : 存在||CExistValidator 的别名, 确保属性值存在于指定的数据表字段中.

['字段名', 'exist'];

file : 文件||CFileValidator 的别名, 确保了特性包含了一个上传文件的名称.

['primaryImage', 'file', 'extensions' => ['png', 'jpg', 'gif'], 'maxSize' => 1024*1024*1024]

filter : 滤镜||CFilterValidator 的别名, 使用一个filter转换属性.

//'skipOnArray' => true 非必填
[['username', 'email'], 'filter', 'filter' => 'trim', 'skipOnArray' => true];

in : 范围||CRangeValidator 的别名, 确保了特性出现在一个预订的值列表里.

['level', 'in', 'range' => [1, 2, 3]];

unique : 唯一性||CUniqueValidator 的别名, 确保了特性在数据表字段中是唯一的.

['字段名', 'unique']

补充:联合唯一索引rule规则

[
    ['app_id', 'group_id'], 
    'unique', 
    'targetAttribute' => ['app_id', 'group_id'], 
    'message' => 'app_id和group_id已经被占用!'
],

integer : 整数

['age', 'integer'];

number : 数字

['salary', 'number'];

double : 双精度浮点型

['salary', 'double'];

date : (日期)

[['from', 'to'], 'date'];

string : 字符串

['username', 'string', 'length' => [4, 24]];

boolean : 是否为一个布尔值||CBooleanValidator 的别名

['字段名', 'boolean', 'trueValue' => true, 'falseValue' => false, 'strict' => true];

image :是否为有效的图片文件

[
    'primaryImage', 
    'image', 
    'extensions' => 'png, jpg',  
    'minWidth' => 100, 'maxWidth' => 1000,  'minHeight' => 100, 'maxHeight' => 1000
]

each:遍历,ids 和 product_ids 是数字的集合

[['ids', 'product_ids'], 'each', 'rule' => ['integer']],

自定义rules:

['password', 'validatePassword'],

/**
 * Validates the password.
 * This method serves as the inline validation for password.
 *
 * @param string $attribute the attribute currently being validated
 * @param array $params the additional name-value pairs given in the rule
 */
public function validatePassword($attribute, $params)
{
    if (!$this->hasErrors()) {
        $user = $this->getUser();
        if (!$user || !$user->validatePassword($this->password)) {
            $this->addError($attribute, '账号或者密码错误!');
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值