Table of Contents
模式行为对应关系
应用行为对应关系
Home Backend Development PHP Tutorial Detailed explanation of ThinkPHP behavioral extensions and plug-ins

Detailed explanation of ThinkPHP behavioral extensions and plug-ins

Jan 03, 2018 am 10:54 AM
php thinkphp plug-in

本文主要介绍了ThinkPHP中的行为扩展和插件原理分析、ThinkPHP中的行为、自定义行为、自定义插件等,给大家提供参考,希望对大家有所帮助。

原理分析

将标签与类之间的对应关系(如'app_init'=>array('Common\Behavior\InitHook')),通过Hook类中import或add方法,加载到Hook类中静态变量$tags中。当执行Hook中静态方法listen或者exec方法的时候(listen方法中调用了exec),实例化标签对应的类,调用相应的方法(如果是插件,调用传递的方法,如果是行为,调用run方法)。
Hook中exec方法定义如下:

1

2

3

4

5

6

7

static public function exec($name, $tag,&$params=NULL) {

       if(false === strpos($name,'\\')) {            // 插件(多个入口)

           $class   "Addons\\{$name}\\{$name}Addon";

       }else{            // 行为扩展(只有一个run入口方法)

           $class   $name.'Behavior';            $tag    =   'run';

       }        $addon   = new $class();        return $addon->$tag($params);

   }

Copy after login
Copy after login

ThinkPHP中的行为 加载标签与类之间的对应关系

// 加载模式行为定义

1

2

3

4

if(isset($mode['tags'])) {

    Hook::import(is_array($mode['tags'])?$mode['tags']:include $mode['tags']);

}// 加载应用行为定义if(is_file(CONF_PATH.'tags.php'))    // 允许应用增加开发模式配置定义

    Hook::import(include CONF_PATH.'tags.php');

Copy after login
Copy after login

模式行为对应关系

在ThinkPHP/Mode/common.php中tags标签中定义

1

2

3

4

5

6

7

'tags'  =>  array(        'app_begin'     =>  array(            'Behavior\ReadHtmlCache', // 读取静态缓存

        ),        'app_end'       =>  array(            'Behavior\ShowPageTrace', // 页面Trace显示

        ),        'view_parse'    =>  array(            'Behavior\ParseTemplate', // 模板解析 支持PHP、内置模板引擎和第三方模板引擎

        ),        'template_filter'=> array(            'Behavior\ContentReplace', // 模板输出替换

        ),        'view_filter'   =>  array(            'Behavior\WriteHtmlCache', // 写入静态缓存

        ),

    )

Copy after login
Copy after login

应用行为对应关系

在Application/Common/Conf/tags.php中定义

调用相应的行为

Detailed explanation of ThinkPHP behavioral extensions and plug-ins

Hook::listen('app_begin')相当于调用Behavior\ReadHtmlCache中的run方法。找到该类,可以查看其对应的run方法如下
Detailed explanation of ThinkPHP behavioral extensions and plug-ins

自定义行为 1.在Application/Common/Conf/tags.php中添加对应关系

1

'dqs_behavior'=>array('Common\Behavior\Dqs')

Copy after login
Copy after login

将对应关系添加到tags.php,程序会自动将其加载到Hook的$tags变量中,当然也可通过使用Hook中的add方法手动加载。

2.定义Common\Behavior\DqsBehavior类

1

2

3

4

5

6

7

<?phpnamespace Common\Behavior;use Think\Behavior;

 

defined(&#39;THINK_PATH&#39;) or exit();class DqsBehavior extends Behavior {

 

    public function run(&$content){

        echo &#39;<pre class="brush:php;toolbar:false">&#39;;

        print_r(&#39;调用了行为Dqs&#39;);        echo &#39;

Copy after login
Copy after login
'; } }

其中Behavior 类为ThinkPHP自带的抽象类

3.调用行为

Detailed explanation of ThinkPHP behavioral extensions and plug-ins

效果如下图
Detailed explanation of ThinkPHP behavioral extensions and plug-ins

自定义插件 1.定义插件文件

通过查看Hook文件中插件类实例化方式($class = "Addons\\{$name}\\{$name}Addon";),可以得知,如果想定义一个名为Dqs的插件,应该在Addons/Dqs目录下定义DqsAddon.class.php文件。程序如下:

1

2

3

4

5

<?phpnamespace Addons\Dqs;class DqsAddon{  

    public $info = array(            &#39;name&#39;=>&#39;Editor&#39;,            &#39;title&#39;=>&#39;dqs测试插件&#39;,            &#39;description&#39;=>&#39;主要用于输出&#39;,            &#39;status&#39;=>1,            &#39;author&#39;=>&#39;lidequan&#39;,            &#39;version&#39;=>&#39;0.1&#39;

    );    public  function dqsTrace($pa){

        echo &#39;<pre class="brush:php;toolbar:false">&#39;;

        print_r($pa);        echo &#39;

Copy after login
Copy after login
'; } }

2.注册插件

所谓的注册插件,就是将插件的标签与类之间的对应关系,添加到Hook类中静态变量$tags中。对应行为来说,标识符仅仅是一个标识符,可以定义任意的标识符,但是对应插件来说,标识符不能随意定义,因为插件的标识符代表的是插件的方法名。所以上面的插件注册代码如下

1

\Think\Hook::add(&#39;dqsTrace&#39;,array(&#39;Dqs&#39;));

Copy after login
Copy after login

3.调用插件

1

2

$params=array(&#39;name&#39;=>&#39;dqs&#39;);

\Think\Hook::listen(&#39;dqsTrace&#39;,$params);

Copy after login
Copy after login

效果如下
Detailed explanation of ThinkPHP behavioral extensions and plug-ins

原理分析

将标签与类之间的对应关系(如&#39;app_init&#39;=>array(&#39;Common\Behavior\InitHook&#39;)),通过Hook类中import或add方法,加载到Hook类中静态变量$tags中。当执行Hook中静态方法listen或者exec方法的时候(listen方法中调用了exec),实例化标签对应的类,调用相应的方法(如果是插件,调用传递的方法,如果是行为,调用run方法)。
Hook中exec方法定义如下:

1

2

3

4

5

6

7

static public function exec($name, $tag,&$params=NULL) {

       if(false === strpos($name,&#39;\\&#39;)) {            // 插件(多个入口)

           $class   "Addons\\{$name}\\{$name}Addon";

       }else{            // 行为扩展(只有一个run入口方法)

           $class   $name.&#39;Behavior&#39;;            $tag    =   &#39;run&#39;;

       }        $addon   = new $class();        return $addon->$tag($params);

   }

Copy after login
Copy after login

ThinkPHP中的行为 加载标签与类之间的对应关系

// 加载模式行为定义

1

2

3

4

if(isset($mode[&#39;tags&#39;])) {

    Hook::import(is_array($mode[&#39;tags&#39;])?$mode[&#39;tags&#39;]:include $mode[&#39;tags&#39;]);

}// 加载应用行为定义if(is_file(CONF_PATH.&#39;tags.php&#39;))    // 允许应用增加开发模式配置定义

    Hook::import(include CONF_PATH.&#39;tags.php&#39;);

Copy after login
Copy after login

模式行为对应关系

在ThinkPHP/Mode/common.php中tags标签中定义

1

2

3

4

5

6

7

&#39;tags&#39;  =>  array(        &#39;app_begin&#39;     =>  array(            &#39;Behavior\ReadHtmlCache&#39;, // 读取静态缓存

        ),        &#39;app_end&#39;       =>  array(            &#39;Behavior\ShowPageTrace&#39;, // 页面Trace显示

        ),        &#39;view_parse&#39;    =>  array(            &#39;Behavior\ParseTemplate&#39;, // 模板解析 支持PHP、内置模板引擎和第三方模板引擎

        ),        &#39;template_filter&#39;=> array(            &#39;Behavior\ContentReplace&#39;, // 模板输出替换

        ),        &#39;view_filter&#39;   =>  array(            &#39;Behavior\WriteHtmlCache&#39;, // 写入静态缓存

        ),

    )

Copy after login
Copy after login

应用行为对应关系

在Application/Common/Conf/tags.php中定义

调用相应的行为

Detailed explanation of ThinkPHP behavioral extensions and plug-ins

Hook::listen(&#39;app_begin&#39;)相当于调用Behavior\ReadHtmlCache中的run方法。找到该类,可以查看其对应的run方法如下
Detailed explanation of ThinkPHP behavioral extensions and plug-ins

自定义行为 1.在Application/Common/Conf/tags.php中添加对应关系

1

&#39;dqs_behavior&#39;=>array(&#39;Common\Behavior\Dqs&#39;)

Copy after login
Copy after login

将对应关系添加到tags.php,程序会自动将其加载到Hook的$tags变量中,当然也可通过使用Hook中的add方法手动加载。

2.定义Common\Behavior\DqsBehavior类

1

2

3

4

5

6

7

<?phpnamespace Common\Behavior;use Think\Behavior;

 

defined(&#39;THINK_PATH&#39;) or exit();class DqsBehavior extends Behavior {

 

    public function run(&$content){

        echo &#39;<pre class="brush:php;toolbar:false">&#39;;

        print_r(&#39;调用了行为Dqs&#39;);        echo &#39;

Copy after login
Copy after login
'; } }

其中Behavior 类为ThinkPHP自带的抽象类

3.调用行为

Detailed explanation of ThinkPHP behavioral extensions and plug-ins

效果如下图
Detailed explanation of ThinkPHP behavioral extensions and plug-ins

自定义插件 1.定义插件文件

通过查看Hook文件中插件类实例化方式($class = "Addons\\{$name}\\{$name}Addon";),可以得知,如果想定义一个名为Dqs的插件,应该在Addons/Dqs目录下定义DqsAddon.class.php文件。程序如下:

1

2

3

4

5

<?phpnamespace Addons\Dqs;class DqsAddon{  

    public $info = array(            &#39;name&#39;=>&#39;Editor&#39;,            &#39;title&#39;=>&#39;dqs测试插件&#39;,            &#39;description&#39;=>&#39;主要用于输出&#39;,            &#39;status&#39;=>1,            &#39;author&#39;=>&#39;lidequan&#39;,            &#39;version&#39;=>&#39;0.1&#39;

    );    public  function dqsTrace($pa){

        echo &#39;<pre class="brush:php;toolbar:false">&#39;;

        print_r($pa);        echo &#39;

Copy after login
Copy after login
'; } }

2.注册插件

所谓的注册插件,就是将插件的标签与类之间的对应关系,添加到Hook类中静态变量$tags中。对应行为来说,标识符仅仅是一个标识符,可以定义任意的标识符,但是对应插件来说,标识符不能随意定义,因为插件的标识符代表的是插件的方法名。所以上面的插件注册代码如下

1

\Think\Hook::add(&#39;dqsTrace&#39;,array(&#39;Dqs&#39;));

Copy after login
Copy after login

3.调用插件

1

2

$params=array(&#39;name&#39;=>&#39;dqs&#39;);

\Think\Hook::listen(&#39;dqsTrace&#39;,$params);

Copy after login
Copy after login

效果如下
Detailed explanation of ThinkPHP behavioral extensions and plug-ins

相关推荐:

详解ThinkPHP如何实现生成和校验验证码

详解如何在云虚拟主机部署thinkphp5项目

thinkPHP5使用laypage分页插件实现列表分页功能_php实例

The above is the detailed content of Detailed explanation of ThinkPHP behavioral extensions and plug-ins. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

CakePHP Project Configuration CakePHP Project Configuration Sep 10, 2024 pm 05:25 PM

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

CakePHP Date and Time CakePHP Date and Time Sep 10, 2024 pm 05:27 PM

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

CakePHP File upload CakePHP File upload Sep 10, 2024 pm 05:27 PM

To work on file upload we are going to use the form helper. Here, is an example for file upload.

CakePHP Routing CakePHP Routing Sep 10, 2024 pm 05:25 PM

In this chapter, we are going to learn the following topics related to routing ?

Discuss CakePHP Discuss CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

How To Set Up Visual Studio Code (VS Code) for PHP Development How To Set Up Visual Studio Code (VS Code) for PHP Development Dec 20, 2024 am 11:31 AM

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

CakePHP Creating Validators CakePHP Creating Validators Sep 10, 2024 pm 05:26 PM

Validator can be created by adding the following two lines in the controller.

See all articles