本文实例讲述了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配置文件定义,格式如下:
<"color: #0000ff">Home\Behaviors\TestBehavior 对应的类是 Home/Behaviors/TestBehavior.class.php。除了这些系统内置标签之外,开发人员还可以在应用中添加自己的应用标签。 比如在控制器的_initialize方法中:
\Think\Hook::add('action_begin','Home\\Behaviors\\TestBehavior'); //同时添加多个行为,只要将第二个参数换成数组即可。行为类的定义,以上面的test行为为例:
<"color: #0000ff">\Think\Behavior,必须实现run(&$param)
方法,行为是通过这个方法执行的。行为的触发: 只要在合适的地方通过以下代码
\Think\Hook::listen('标签名'[,参数]); // 或者 // tag('标签名'[,参数]);当应用执行到这个地方的时候将自动触发指定标签名下的所有行为类。
isten方法可以传入并且只接受一个参数,如果需要传入多个参数,请使用数组,该参数为引用传值,所以只能传入变量。 参数可以被
run(&$param)
中的$param
接收。更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。