關(guān)于Yii中模型場(chǎng)景的一些簡(jiǎn)單介紹
前言
在Yii中模型字段驗(yàn)證有一個(gè)場(chǎng)景的概念,可以在不同的場(chǎng)景下設(shè)置不同的驗(yàn)證規(guī)則,在Yii中的場(chǎng)景默認(rèn)為default,簡(jiǎn)單實(shí)現(xiàn)如下
下面我以用戶表,表中字段為user_name,password
簡(jiǎn)單規(guī)則如下
public function rules() {
return [
[['user_name', 'password'], 'required'],
[['user_name', 'password'], 'string', 'max' => 255],
];
}
一:
如果我們需要在新增時(shí)驗(yàn)證user_name和password兩個(gè)字段,在更新時(shí)只驗(yàn)證user_name字段
這時(shí)候我們可以在模型中覆蓋yiibaseModel::scenarios()方法來自定義行為
public function scenarios()
{
return [
'create' => ['user_name', 'password'],//create表示新增場(chǎng)景
'update' => ['user_name'],//update表示更新場(chǎng)景
];
}
根據(jù)上面設(shè)置的場(chǎng)景規(guī)則,我們只需要在我們新增和更新時(shí)設(shè)置為指定的場(chǎng)景即可
// 場(chǎng)景作為屬性來設(shè)置 $model = new User; $model->scenario = 'create'; // 場(chǎng)景通過構(gòu)造初始化配置來設(shè)置 $model = new User(['scenario' => 'create']);
根據(jù)如上就可以實(shí)現(xiàn)在不同的場(chǎng)景下驗(yàn)證指定的字段
二:
我們可以在規(guī)則rule中使用on屬性來設(shè)置不同的場(chǎng)景
public function rules()
{
return [
[['id'], 'integer'],
[['user_name'], 'required'],
[['password'], 'required', 'on' => 'create']
[['user_name', 'password'], 'string', 'max' => 255],
];
}
根據(jù)如上在create場(chǎng)景下password字段必填
三:
使用yiibaseModel::validate() 來驗(yàn)證接收到的數(shù)據(jù)
$model = new User(); $model->validate(['user_name'])
使用validate方法驗(yàn)證user_name,驗(yàn)證通過返回true,否則返回false
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
- Yii2中的場(chǎng)景(scenario)和驗(yàn)證規(guī)則(rule)詳解
- Yii2中簡(jiǎn)單的場(chǎng)景使用介紹
- Yii 2.0中場(chǎng)景的使用教程
- Yii2.0框架behaviors方法使用實(shí)例分析
- yii2.0框架使用 beforeAction 防非法登陸的方法分析
- YII2.0框架行為(Behavior)深入詳解
- Yii2.0框架實(shí)現(xiàn)帶分頁(yè)的多條件搜索功能示例
- Yii2.0 RESTful API 基礎(chǔ)配置教程詳解
- 修改yii2.0用戶登錄使用的user表為其它的表實(shí)現(xiàn)方法(推薦)
- yii2.0框架場(chǎng)景的簡(jiǎn)單使用示例
相關(guān)文章
Laravel 6.2 中添加了可調(diào)用容器對(duì)象的方法
Laravel小組上周發(fā)布了v6.2.0 版本,接下來通過本文給大家分享Laravel 6.2 中添加了可調(diào)用容器對(duì)象的方法,需要的朋友可以參考下2019-10-10
對(duì)laravel的csrf 防御機(jī)制詳解,及form中csrf_token()的存在介紹
對(duì)laravel的csrf 防御機(jī)制詳解,及對(duì)laravel的csrf 防御機(jī)制詳解,及form中csrf_token()的存在介紹,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-10-10
Thinkphp中的volist標(biāo)簽用法簡(jiǎn)介
通常volist標(biāo)簽多用于查詢數(shù)據(jù)集(select方法)的結(jié)果輸出,通常模型的select方法返回的結(jié)果是一個(gè)二維數(shù)組,對(duì)此可以直接使用volist標(biāo)簽進(jìn)行輸出2014-06-06
TP5框架簡(jiǎn)單登錄功能實(shí)現(xiàn)方法示例
這篇文章主要介紹了TP5框架簡(jiǎn)單登錄功能實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了thinkPHP5框架登錄功能控制器、視圖、登錄驗(yàn)證等相關(guān)操作技巧,需要的朋友可以參考下2019-10-10
php中實(shí)現(xiàn)記住密碼下次自動(dòng)登錄的例子
這篇文章主要介紹了php中實(shí)現(xiàn)記住密碼下次自動(dòng)登錄的例子,本文使用cookie實(shí)現(xiàn)記住密碼和自動(dòng)登錄功能,需要的朋友可以參考下2014-11-11
ThinkPHP實(shí)現(xiàn)事務(wù)回滾示例代碼
這篇文章主要介紹了ThinkPHP實(shí)現(xiàn)事務(wù)回滾,需要的朋友可以參考下2014-06-06

