이 글에서는 thinkPHP 프레임워크 자동 채우기를 주로 소개합니다. thinkPHP 프레임워크 자동 채우기의 원리, 사용 방법 및 관련 동작 주의 사항을 예제 형식으로 자세히 분석합니다. 필요한 친구들이 참고할 수 있습니다.
이 글은 thinkPHP를 분석합니다. 예제를 이용한 프레임워크 자동 채우기. 참고를 위해 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.
thinkphp에는 필드를 자동으로 채우는 방법이 있습니다
채우기 규칙은 다음과 같습니다
array( array(完成字段1,完成规则,[完成条件,附加规则]), array(完成字段2,完成规则,[完成条件,附加规则]), ...... );
참고: 소스를 연구한 후 코드에서 실제로 4번째 매개변수가 있는 것을 발견했습니다. 이 매개변수는 매개변수를 함수나 콜백 메소드에 전달하는 데 사용됩니다. 매개변수 1은 기본적으로 필드 값 로 설정됩니다. 예:
array('mobile','trim',3,'function',参数2,参数3'),
결제 동적 및 정적 확인
모델 클래스의 정적 검증
모델의 자동 검증 규칙이 미리 정의되어 있으며 create
메소드를 사용한 후 자동으로 검증됩니다. 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; }2. 호출 시
create
메소드를 사용하여 자동으로 채워주세요 동적 검증
핵심 코드 분석은 다음과 같습니다.
create 메소드 호출 후 autoOperation
code> 메소드는 다음과 같이 호출됩니다
위 내용은 thinkPHP 프레임워크의 자동 채우기 원리 및 분석에 대해의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!