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

Thinkphp 框架扩展之行为扩展原理与实现方法分析

发布:smiling 来源: PHP粉丝网  添加日期:2022-03-02 09:35:08 浏览: 评论:0 

这篇文章主要介绍了Thinkphp 框架扩展之行为扩展,结合实例形式分析了Thinkphp 框架行为扩展相关原理、实现方法及操作注意事项,需要的朋友可以参考下。

本文实例讲述了Thinkphp 框架扩展之行为扩展原理与实现方法,分享给大家供大家参考,具体如下:

系统核心提供的标签位置包括下面几个(按照执行顺序排列):

app_init 应用初始化标签位

path_info PATH_INFO检测标签位

app_begin 应用开始标签位

action_name 操作方法名标签位

action_begin 控制器开始标签位

view_begin 视图输出开始标签位

view_parse 视图解析标签位

template_filter 模板内容解析标签位

view_filter 视图输出过滤标签位

view_end 视图输出结束标签位

action_end 控制器结束标签位

app_end 应用结束标签位

在每个标签位置,可以配置多个行为定义,行为的执行顺序按照定义的顺序依次执行。除非前面的行为里面中断执行了(某些行为可能需要中断执行,例如检测机器人或者非法执行行为),否则会继续下一个行为的执行,行为定义: 通过Common\Conf\tags.php配置文件定义,格式如下:

  1. <?php 
  2. return array
  3.   'action_begin'=>array('Home\\Behaviors\\TestBehavior','Home\\Behaviors\\Test1Behavior'),  
  4. ); 

上面注册了两个行为,分别是Home模块下的test和test1行为,类文件位于Home模块目录下的Behaviors目录,可以自定义目录。

行为必须是一个包含命名空间路径的类,如上的 Home\Behaviors\TestBehavior 对应的类是 Home/Behaviors/TestBehavior.class.php。

除了这些系统内置标签之外,开发人员还可以在应用中添加自己的应用标签,比如在控制器的_initialize方法中:

\Think\Hook::add('action_begin','Home\\Behaviors\\TestBehavior');

//同时添加多个行为,只要将第二个参数换成数组即可。

行为类的定义,以上面的test行为为例:

  1. <?php 
  2. namespace Home\Behaviors; 
  3. class TestBehavior extends \Think\Behavior{ 
  4.   //行为执行入口 
  5.   public function run(&$param){ 
  6.    
  7.   } 

行为类建议继承\Think\Behavior,必须实现run(&$param)方法,行为是通过这个方法执行的。

行为的触发: 只要在合适的地方通过以下代码

  1. \Think\Hook::listen('标签名'[,参数]); 
  2. // 或者 
  3. // tag('标签名'[,参数]); 

当应用执行到这个地方的时候将自动触发指定标签名下的所有行为类。

isten方法可以传入并且只接受一个参数,如果需要传入多个参数,请使用数组,该参数为引用传值,所以只能传入变量,参数可以被run(&$param)中的$param接收。

Tags: Thinkphp框架扩展 Thinkphp扩展

分享到: