yii2场景使用

yii2场景使用

现在在post表里面有title,image,content三个的字段,yii2处理post请求的时候,我想三个字段全部是必填项,但是你修改的时候,title content 两个字段是必填的, iamge 可以不填写。正常的情况下,[[‘title’, ‘content’, ‘image’], ‘required’,], 但是我们更改的时候 只需要 [[‘title’, ‘content’], ‘required’], 就可以了,但是少了 image 字段 我们的表单就无法提交,场景可以帮你解决这种问题,下面是一个简单的场景实例。

1、首先我们在 model 里面定义一下场景 类名必须是 scenarios()

public function scenarios()
{
    return [
        'create' => ['title', 'image', 'content'],
        'update' => ['title', 'content'],
    ];
}

2、好的,如上所示,场景的基本设置我们就已经完成一部分了,下面我们设置 rules() ,调用场景我们用 on 关键字

public function rules()
{
    return [
        [['title', 'content'], 'required', 'on' => ['create', 'update']],
        [['image'], 'required', 'on' => 'create'],
        [['image'], 'image', 'enableClientValidation' => true,   'maxSize' => 1024, 'message' => '您上传的文件过
大', 'on' => ['create']],
    ];
}

更优的代码

public function scenarios()
    {
          //合并了父类scenarios方法的default场景,避免了设置场景后没有设置场景(没有设置场景是default场景)的模型rules验证问题
        return array_merge(parent::scenarios(), [
            'create' => ['title', 'image', 'content'],
            'update' => ['title', 'content'],
        ]);
    }

on 指定的就是场景,一个场景用字符串,多个场景用数组

3、好的,model 里面我们就设置完毕了 现在开始调用吧。 Controller 里面

$model = $this->findModel($id);
$model->setScenario('update'); or $model->scenario = 'update';

上面的意思就是 调用 update 场景。一切就是这么简单,

4、其他使用方法等价于上面的使用方式,一般上面的方式多用于update,而下面的方式多用于create

$model = UserModel(['scenario' => 'create']);
//可以省略改行代码$model->setScenario('create'); or $model->scenario = 'create';

猜你喜欢

转载自blog.csdn.net/u011552182/article/details/80846187