本文着重介绍了“钩子”的应用程序接口,这里的钩子又被称为“过滤器”和“动作”。WordPress通过钩子来运行插件。这些钩子也可以用在主题中,WordPress中插件开发人员可以使用的API(应用程序接口)钩子(hook)进行扩展开发

钩子,动作与过滤器

WordPress用钩子将插件“勾进”WordPress系统中,让插件与WordPress相连接。也就是说,通过钩子,WordPress能够在特定时间内调用插件中的函数,让插件开始运行。下面是钩子的两种形式:

  1. 动作(Actions):在系统运行的某些特定时间点或发生特定事件时,WordPress核心程序会调用一些钩子。这里WordPress所调用的钩子被称为“动作”。插件用动作API来指定在上述特定时间点内需要执行的PHP函数。
  1. 过滤器(Filters):WordPress将不同类型文本添加到数据库或发送给浏览器窗口前,需要调用一些钩子来修改上述不同类型文本。这里WordPress所调用的钩子被称为“过滤器”。通过使用滤器API,插件可以执行一个或多个PHP函数以修改上述不同类型文本。

有时我们可以直接通过动作或过滤器实现以上效果。例如,如果我们希望用插件来改变某篇日志内容,可以为publish_post添加一个动作函数(保存到数据库时修改日志),也可以为the_content添加一个过滤器函数(显示到浏览器窗口时修改日志)。

函数引用

过滤器函数

  • has_filters
  • add_filter()
  • apply_filters()
  • current_filter
  • merge_filters()
  • remove_filter()
  • remove_all_filters

动作函数

  • has_action
  • add_action
  • do_action
  • do_action_ref_array
  • did_action
  • remove_action
  • remove_all_actions

动作

动作由发生在WordPress中的特定事件触发,如发表日志、更改主题、显示控制板页面等。插件以执行PHP函数的方式来响应该事件,函数的作用可能是:

更改数据库资料
发送电子邮件消息
更改浏览器窗口上显示的信息(网站管理员或终端用户)
基本步骤如下(下文中有详细介绍):

  1. 在插件文件中创建一个可以在事件发生时执行的PHP函数
  2. 调用add_action,将动作函数勾入WordPress
  3. 将创建的PHP函数存放在插件文件中,激活该函数

创建动作函数

要在插件中新建一个动作函数,首先要用插件中该动作的功能来创建一个PHP函数,然后将函数存入插件文件(我们需要将插件文件放在wp-content/plugins目录下)。例如,如果我们希望每次我们发表新日志,博客都会以电子邮件的方式通知我们的朋友,我们可以定义以下函数:

1
2
3
4
5
6
function email_friends($post_ID)  {
$friends = 'bob@example.org,susie@example.org';
mail($friends, "sally's blog updated",
'I just put something on my blog: http://blog.example.com');
return $post_ID;
}

大多数动作函数都能接受一个参数(通常是日志ID或评论ID,取决于动作的性质)。有些动作函数能接收更多参数——更多信息请参照动作的说明文档或WordPress源代码。除参数外,我们也可以获取WordPress的全局变量,调用其它WordPress函数(或插件文件中的函数)。

函数输出的内容会出现在调用动作的页面源代码中。

注意:其它插件或WordPress核心文件中的函数可能已经使用了我们所创建的函数名称。

勾入WordPress(连接到WordPress程序中)

定义PHP函数后,我们要将函数连接到WordPress中。可以在插件文件的全局变量执行域中调用add_action来实现连接:

add_action ( ‘hook_name’, ‘your_function_name’, [priority], [accepted_args] );
其中:

hook_name

WordPress动作钩子的名称,通过名称我们可以了解到函数与什么事件相关联。

your_function_name

hook_name指定事件后,需要执行的函数名。函数需要是WordPress核心文件中的标准PHP函数,或是我们在插件文件中定义的函数(如上文中定义的’email_friends’)。

priority

用一个可选的整数型变量来规定函数(与特定动作相关联)的执行顺序,变量值默认为10。若某函数的priority值小于10,优先执行该函数。如果若干函数priority值相等,则按加入动作的顺序执行函数。

accept_args

用一个可选的整数型变量来定义函数能够接受的参数数量(默认值为1)。有些钩子能够向函数传递一个以上参数,因此accept_args实用价值较大。参数引进于WordPress 1.5.1。

根据上面的例子,我们要在插件文件中加入以下代码行:

add_action ( ‘publish_post’, ‘email_friends’ );
同样,我们也可以删除动作钩子中的动作。

安装与激活

最后我们要安装文件、激活插件以运行动作钩子。我们要将创建的PHP函数和add_filter调用存入一个PHP文件并将该PHP文件安装在wp-content/plugins目录下。安装完毕后,在WordPress的管理界面中激活插件;参见管理插件。

当前动作钩子

插件API/常用动作(action)中列出了WordPress现有动作钩子以及之前WordPress版本的链接。

过滤器(Filters)

过滤器是WordPres在运行中的特定时间点、对数据进行操作(如将数据加入数据库,或将数据发送到浏览器窗口上)前,用来传递数据的函数。WordPress生成页面时,过滤器位于数据库和浏览器之间;当WordPress将新日志和评论加入到数据库中时,过滤器位于浏览器和数据库之间。WordPress中大多数输入和输出内容都至少经过一个过滤器的传递。默认情况下WordPress会执行一些过滤行为,但插件也可以添加自己的过滤器函数。

将过滤器函数加入WordPress的基本步骤如下(下文中有详细描述):

  1. 创建一个可以过滤数据的PHP函数
  2. 调用add_filter(),将过滤器函数勾入WordPress
  3. 将创建的PHP函数存放在插件文件中,激活该函数

创建过滤器函数

过滤器函数将未经修改的数据作为输入内容,返回修改后的数据(有时会返回空值来表示该数据应该被删除或忽略)。如果过滤器函数没有对数据做修改,则应该返回原始数据,方便插件必要时修改数据值。

因此要在插件中新建一个过滤器函数,首先要创建一个PHP函数负责过滤,然后将该PHP函数存入插件文件(插件文件必须位于wp-content/plugins目录下)。例如,如果希望我们的日志和评论中没有亵渎性语言,我们需要定义一个全局变量,列出所有不允许出现的词语,然后创建PHP函数:

function filter_profanity($content) { global $profanities; $content=str_ireplace($profanities,'{censored}',$content); return $content; }
为什么这里不用循环也可以?这是因为$profanities是一个数组,str_replace可以帮我们循环该数组。

注意:其它插件或WordPress核心文件中的函数可能已经使用了我们所创建的函数名称。

将过滤器勾入WordPress(连接到WordPress程序中)

定义PHP函数后,我们要将过滤器函数连接到WordPress中。可以在插件文件的全局变量执行域中调用add_filter来实现连接:

add_filter ( ‘hook_name’, ‘your_filter’, [priority], [accepted_args] );
其中:

hook_name

WordPress过滤器钩子的名称,通过名称我们可以了解到什么时候需要用到过滤器函数。

your_function_name

用于过滤的函数的名称。函数需要是WordPress核心文件中的标准PHP函数,或是我们在插件文件中定义的函数。

priority

用一个可选的整数型变量来规定函数(该函数与特定过滤器相关联)的执行顺序,变量值默认为10。若某函数的priority值小于10,优先执行该函数。如果若干函数priority值相等,则按加入过滤器的顺序执行函数。

accept_args

用一个可选的整数型变量来定义函数能够接受的参数数量(默认值为1)。有些钩子能够向函数传递一个以上参数,因此accept_args实用价值较大。

根据上面的例子,我们要在插件文件的主执行区域中加入以下代码行,让WordPress过滤含有亵渎性内容的评论:

add_filter(‘comment_text’,’filter_profanity’);

我们也可以用remove_filter()删除过滤器钩子中的过滤器函数。

安装与激活

最后我们要安装文件、激活插件以运行过滤器钩子。我们要将创建的PHP函数和add_filter调用存入一个PHP文件并且将该PHP文件安装在wp-content/plugins目录下。安装完毕后,在WordPress的管理界面中激活插件;参见管理插件。

当前过滤器钩子

插件API/常用动作(action)中列出了WordPress现有过滤器钩子以及之前WordPress版本的链接。

示例

这是wp-hackers邮件列表中的一个示例。该示例用一个插件来更改(或重写)默认的bloginfo()函数。这将会修改核心函数。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
add_filter('bloginfo', 'mybloginfo', 1, 2);
add_filter('bloginfo_url', 'mybloginfo', 1, 2);

function mybloginfo($result='', $show='') {
switch ($show) {
case 'wpurl':
$result = SITE_URL;
break;
case 'template_directory':
$result = TEMPL_DIR;
break;
default:
}
return $result;
}

删除动作和过滤器

有时我们可能会希望插件禁用WordPress内置的、或者其它插件创建的某个动作或过滤器。这时可以调用remove_filter(‘filter_hook’,’filter_function’)或remove_action(‘action_hook’,’action_function’)帮助我们达到期望的效果。

例如发表新日志时,用remove_action(‘publish_post’,’generic_ping’); 可以阻止博客发送ping。

注意,如果钩子优先级的值不是10,那么我们必须在调用remove_action时指定优先级。一般来说,除非我们完全了解所要删除的信息以及信息的作用,否则不能随意删除任何信息——可以查看WordPress源代码或者其它插件源代码以了解信息。

可插入式函数

除了上面介绍的钩子(动作和过滤器),我们还可以通过重写WordPress函数来让插件影响WordPress的运行。事实上,WordPress为插件提供了一个能够重新定义的小型函数集。函数集中的函数被称为可插入式函数,存储在wp-includes/pluggable.php下。如果所有插件都加载完毕后,可插入式函数仍然处于未定义状态,这时WordPress会加载这些函数。