当前位置:首页 > CMS教程 > Thinkphp > 列表

thinkPHP框架自动填充原理与用法分析

发布:smiling 来源: PHP粉丝网  添加日期:2021-09-06 10:10:20 浏览: 评论:0 

这篇文章主要介绍了thinkPHP框架自动填充,结合实例形式较为详细的分析了thinkPHP框架自动填充的原理、使用方法及相关操作注意事项,需要的朋友可以参考下。

本文实例分析了thinkPHP框架自动填充原理与用法,分享给大家供大家参考,具体如下:

thinkphp有一个自动填充字段的方法

填充规则如下

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

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

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

验证支付动态和静态

静态验证

在模型类里面预先定义好该模型的自动验证规则,在使用create方法后会自动去验证。

以下是官方的例子

1.首先在模型中定义好验证的规则

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

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

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

动态验证

以下是官方的例子

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

下面是核心的代码分析:

create方法调用后会调用autoOperation方法,方法如下

  1. /** 
  2.  * 自动表单处理 
  3.  * @access public 
  4.  * @param array $data 创建数据 
  5.  * @param string $type 创建类型 
  6.  * @return mixed 
  7.  */ 
  8. private function autoOperation(&$data,$type) { 
  9.   if(!emptyempty($this->options['auto'])) { 
  10.     $_auto  =  $this->options['auto']; 
  11.     unset($this->options['auto']); 
  12.   }elseif(!emptyempty($this->_auto)){ 
  13.     $_auto  =  $this->_auto; 
  14.   } 
  15.   // 自动填充 
  16.   if(isset($_auto)) { 
  17.     foreach ($_auto as $auto){ 
  18.       // 填充因子定义格式 
  19.       // array('field','填充内容','填充条件','附加规则',[额外参数]) 
  20.       if(emptyempty($auto[2])) $auto[2] = self::MODEL_INSERT; // 默认为新增的时候自动填充 
  21.       //这里的判断是关键,$type为当前的操作状态,值为1表示是插入,值为2表示是更新 
  22.       //如果当前的$type状态值等于设置的值$auto[2]或者$auto[2]的值为3,代表需要填充 
  23.       if$type == $auto[2] || $auto[2] == self::MODEL_BOTH) { 
  24.         if(emptyempty($auto[3])) $auto[3] = 'string'
  25.         switch(trim($auto[3])) { 
  26.           case 'function':  // 使用函数进行填充 字段的值作为参数 
  27.           case 'callback'// 使用回调方法 
  28.             $args = isset($auto[4])?(array)$auto[4]:array(); 
  29.             if(isset($data[$auto[0]])) { 
  30.               array_unshift($args,$data[$auto[0]]); 
  31.             } 
  32.             if('function'==$auto[3]) { 
  33.               $data[$auto[0]] = call_user_func_array($auto[1], $args); 
  34.             }else
  35.               $data[$auto[0]] = call_user_func_array(array(&$this,$auto[1]), $args); 
  36.             } 
  37.             break
  38.           case 'field':  // 用其它字段的值进行填充 
  39.             $data[$auto[0]] = $data[$auto[1]]; 
  40.             break
  41.           case 'ignore'// 为空忽略 
  42.             if($auto[1]===$data[$auto[0]]) 
  43.               unset($data[$auto[0]]); 
  44.             break
  45.           case 'string'
  46.           default// 默认作为字符串填充 
  47.             $data[$auto[0]] = $auto[1]; 
  48.         } 
  49.         if(isset($data[$auto[0]]) && false === $data[$auto[0]] )  unset($data[$auto[0]]); 
  50.       } 
  51.     } 
  52.   } 
  53.   return $data
  54. }

Tags: thinkPHP自动填充

分享到: