行为扩展_扩展_帮助文档_Thinkphp手册

行为扩展_扩展_帮助文档_Thinkphp手册

行为(Behavior)是一个比较抽象的概念,你可以想象成在应用执行过程中的一个动作或者处理,在框架的执行流程中,各个位置都可以有行为产生,例如路由检测是一个行为,静态缓存是一个行为,用户权限检测也是行为,大到业务逻辑,小到浏览器检测、多语言检测等等都可以当做是一个行为,甚至说你希望给你的网站用户的第一次访问弹出Hello,world!这些都可以看成是一种行为,行为的存在让你无需改动框架和应用,而在外围通过扩展或者配置来改变或者增加一些功能。

而不同的行为之间也具有位置共同性,比如,有些行为的作用位置都是在应用执行前,有些行为都是在模板输出之后,我们把这些行为发生作用的位置称之为标签(位),当应用程序运行到这个标签的时候,就会被拦截下来,统一执行相关的行为,类似于AOP编程中的“切面”的概念,给某一个切面绑定相关行为就成了一种类AOP编程的思想。

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

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

上面注册了两个行为,分别是Home模块下的test和test1行为,类文件位于Home模块目录下的Behaviors目录,可以自定义目录。 行为必须是一个包含命名空间路径的类,如上的 Home/Behaviors/test 对应的类是 Home/Behaviors/testBehavior.class.php。

注意:注册行为的时候行为名不需要加Behavior后缀,但是创建类文件的时候需要在行为名test后面加上Behavior,以及类文件扩展名是.class.php。

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

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

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

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

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

注意:动态注册的行为必须在Hook::listen之前,即:先注册行为,才能触发行为。

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

未经允许不得转载:淘淘源码吧 » 行为扩展_扩展_帮助文档_Thinkphp手册