zoukankan      html  css  js  c++  java
  • yii2场景的应用(scenarios)

    例如:

    现在在 post表里面有 title image content 三个的字段,当我创建一个 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 关键字

    [['title', 'content'], 'required', 'on' => ['create', 'update']],
    [['image'], 'required', 'on' => 'create'],
    [['image'], 'image', 'enableClientValidation' => true,   'maxSize' => 1024, 'message' => '您上传的文件过
    大', 'on' => ['create']],

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

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

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

    上面的意思就是 调用 update 场景。

    原文链接:http://www.yiichina.com/tutorial/89

  • 相关阅读:
    java-scanner
    java-hashmap
    单点故障和脑裂
    Client将数据读写HDFS流程
    Zookeeper的作用,在Hadoop及hbase中具体作用
    hadoop 管理命令dfsadmin
    如何确定 Hadoop map和reduce的个数--map和reduce数量之间的关系是什么?
    Spark 数据倾斜
    zookeeper选举
    hive安装详解
  • 原文地址:https://www.cnblogs.com/chrdai/p/9115850.html
Copyright © 2011-2022 走看看