zoukankan      html  css  js  c++  java
  • thinkphp自动填充分析

    thinkphp有一个自动填充字段的方法
    填充规则如下

    array(
         array(完成字段1,完成规则,[完成条件,附加规则]),
         array(完成字段2,完成规则,[完成条件,附加规则]),
         ......
    );
    

    注:研究源码后发现其实还有第4个参数,是给函数或者回调方法传参数用的,参数1默认为该字段值,如:

    array('mobile','trim',3,'function',参数2,参数3'),  
    

    验证支付动态和静态
    静态验证
    在模型类里面预先定义好该模型的自动验证规则,在使用create方法后会自动去验证。
    以下是官方的例子
    1.首先在模型中定义好验证的规则

    namespace HomeModel;
    use ThinkModel;
    class UserModel extends Model{
         protected $_auto = array ( 
             array('status','1'),  // 新增的时候把status字段设置为1
             array('password','md5',3,'function') , // 对password字段在新增和编辑的时候使md5函数处理
             array('name','getName',3,'callback'), // 对name字段在新增和编辑的时候回调getName方法
             array('update_time','time',2,'function'), // 对update_time字段在更新的时候写入当前时间戳
         );
    }
    

     2.在调用的时候用create方法会自动进行填充

    $User = D("User"); // 实例化User对象
    if (!$User->create()){ // 创建数据对象
         // 如果创建失败 表示验证没有通过 输出错误提示信息
         exit($User->getError());
    }else{
         // 验证通过 写入新增数据
         $User->add();
    }
    

    动态验证
    以下是官方的例子

    $rules = array ( 
        array('status','1'),  // 新增的时候把status字段设置为1
        array('password','md5',3,'function') , // 对password字段在新增和编辑的时候使md5函数处理
        array('update_time','time',2,'function'), // 对update_time字段在更新的时候写入当前时间戳
    );
    $User = M('User');
    $User->auto($rules)->create();
    $User->add();
    

     下面是核心的代码分析:
    create方法调用后会调用autoOperation方法,方法如下

    /**
     * 自动表单处理
     * @access public
     * @param array $data 创建数据
     * @param string $type 创建类型
     * @return mixed
     */
    private function autoOperation(&$data,$type) {
        if(!empty($this->options['auto'])) {
            $_auto   =   $this->options['auto'];
            unset($this->options['auto']);
        }elseif(!empty($this->_auto)){
            $_auto   =   $this->_auto;
        }
        // 自动填充
        if(isset($_auto)) {
            foreach ($_auto as $auto){
                // 填充因子定义格式
                // array('field','填充内容','填充条件','附加规则',[额外参数])
                if(empty($auto[2])) $auto[2] =  self::MODEL_INSERT; // 默认为新增的时候自动填充
                //这里的判断是关键,$type为当前的操作状态,值为1表示是插入,值为2表示是更新
                //如果当前的$type状态值等于设置的值$auto[2]或者$auto[2]的值为3,代表需要填充
                if( $type == $auto[2] || $auto[2] == self::MODEL_BOTH) {
                    if(empty($auto[3])) $auto[3] =  'string';
                    switch(trim($auto[3])) {
                        case 'function':    //  使用函数进行填充 字段的值作为参数
                        case 'callback': // 使用回调方法
                            $args = isset($auto[4])?(array)$auto[4]:array();
                            if(isset($data[$auto[0]])) {
                                array_unshift($args,$data[$auto[0]]);
                            }
                            if('function'==$auto[3]) {
                                $data[$auto[0]]  = call_user_func_array($auto[1], $args);
                            }else{
                                $data[$auto[0]]  =  call_user_func_array(array(&$this,$auto[1]), $args);
                            }
                            break;
                        case 'field':    // 用其它字段的值进行填充
                            $data[$auto[0]] = $data[$auto[1]];
                            break;
                        case 'ignore': // 为空忽略
                            if($auto[1]===$data[$auto[0]])
                                unset($data[$auto[0]]);
                            break;
                        case 'string':
                        default: // 默认作为字符串填充
                            $data[$auto[0]] = $auto[1];
                    }
                    if(isset($data[$auto[0]]) && false === $data[$auto[0]] )   unset($data[$auto[0]]);
                }
            }
        }
        return $data;
    }
    
  • 相关阅读:
    C# 中的EventHandler
    Leetcode:Combinations 组合
    Leetcode:Minimum Path Sum
    [LeetCode] Container With Most Water
    一个数n的最少可以由多少个数的平方和组成
    单链表的归并排序
    几个常用的操作系统进程调度算法(转)
    字符串的最长重复子串(转)
    linux静态链接库与动态链接库详解
    简易的hashtable实现
  • 原文地址:https://www.cnblogs.com/chenqionghe/p/4671105.html
Copyright © 2011-2022 走看看