本文实例讲述了Yii核心验证器api。分享给大家供大家参考,具体如下:
核心验证器 Core Validators
前言
Yii 提供了一系列常用的核心 validators, 你可在
yii/validators namespace 中找到. 不用使用长的验证器类名, 你可以使用别名代替他们.
例如, 你可以使用别名 required 代替 yii/validators/RequiredValidator 类:
<?phppublic function rules(){ return [ [['email', 'password'], 'required'], ];}?>
这个 yii/validators/Validator::$builtInValidators 属性生命所有支持的验证器的别名.
接下来, 我们将讲解每种核心验证器的用法.
1. boolean 对错值
<?php[ // 检查是否 "selected" 是 0 或 1, 不管数据类型 ['selected', 'boolean'], // 检查是否 "deleted" 是一个 boolean 类型, 只能是 true 或则 false ['deleted', 'boolean', 'trueValue' => true, 'falseValue' => false, 'strict' => true],]?>
上面检测是否是一个bool值.
trueValue: 代表true时的值. 默认为 '1'.
falseValue: 代表 false 时的值. 默认为 '0'.
strict: 是否输入框中的值必须匹配 设置的 trueValue 和 falseValue. 默认为 false.
注意: 因为数据提交通过HTML形式都是字符创, 一般你需要设置 strict 属性为 false.
2. captcha 验证码
<?php[ ['verificationCode', 'captcha'],]?>
这个验证器通常和
yii/captcha/CaptchaAction 以及
yii/captcha/Captcha 一起使用以确保输入的是相同的验证码 通过 CAPTCHA 组件.
caseSensitive: 是否验证码需要区分大小写. 默认为 false.
captchaAction: 默认的验证码的 CAPTCHA action 生成 CAPTCHA image的路径. 默认为 'site/captcha'.
skipOnEmpty: 输入为空的时候是否跳过验证. 默认false, 即 input 输入是必须的.
3. compare 比较
<?php[ // 验证是否 "password" 属性和 "password_repeat"是否相等 ['password', 'compare'], // 验证 age >= 30 ['age', 'compare', 'compareValue' => 30, 'operator' => '>='],]?>
这个验证器比较指定的输入值和另一个值确保他们之间使用指定的操作符.
compareAttribute: 属性的名字即将会和谁比较.当验证器被用来验证一个属性的时候, 他会和属性名字相同 但带有后缀 _repeat的属性相比较. 例如, 如果要验证的属性名是 password, 那么默认对比的属性名就是 password_repeat 你可以指定你想要的值.
compareValue: 一个和输入值比较的常量值. 当 property 和 compareAttribute 属性被同时指定的时候, 这个值将优先.
operator: 比较的操作符. 默认是 ==, 即输入值和 compareAttribute 或 compareValue 值相等的时候才会成功.
支持下面这些操作符: ==、===、!=、!==、>、>=、<、<=。
新闻热点
疑难解答