博客列表 >thinkPHP框架自动填充原理与用法分析

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

php开发大牛
php开发大牛原创
2018年04月19日 15:31:56664浏览

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

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

填充规则如下

array(

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

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

   ......

);

   

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

   

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

   

验证支付动态和静态

静态验证

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

以下是官方的例子

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

   

namespace Home\Model;

use Think\Model;

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;

}

   

更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。


声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议