WordPress 之所以能成为世界上最受欢迎的网页内容管理系统,原因就在于它的高度灵活性和可塑性,而这种灵活性和可塑性正是由“挂钩”(Hooks)简洁宜用的结构所决定的。可以说,没有过滤挂钩(Filter Hooks)和动作挂钩(Action Hooks), WordPress 就不会具有这样高的可拓展性,我们也不可能会有如此多的 WordPress 插件和主题可供选择。

在本系列教程中,我将会向你详细介绍 WordPress 中的动作挂钩。在整个教程中,我们将会涵盖有关动作挂钩几乎所有方面的内容。

  • 在第一部分,也就是在本文中,我们将会逐步了解到 WordPress 动作挂钩:什么是 WordPress 动作挂钩,以及怎样使用 WordPress 的7大核心动作挂钩。
  • 在接下来的五个部分,我们将会接触到大量有关 WordPress 动作挂钩的实例。而在每一个部分,我们都会了解到10个挂钩的优点和它们的使用条件,并通过一些实例来进一步掌握它们。
  • 在本系列课程的最后,我们将会进行一次课程回顾与总结,包括所举的50个例子。

这个学习过程将会非常漫长,所以,请做好准备。

什么是 WordPress 动作挂钩

在 Codex ( WordPress 法典)中,给出的定义如下:

动作挂钩由 WordPress 中的特定事件激活,例如:发布一篇文章、更改主题,或者是显示管理控制界面( administration screen)。动作挂钩是在插件(或主题)中定义的自定义PHP函数,即被设定为回应某些特定事件。

所以,从本质上来说,动作挂钩由某个 WordPress 事件激活,可以在事件之前或之后运行。动作挂钩只是WordPress的两种挂钩之一,另一个则是我们之前讲到的过滤挂钩(Filters)——如果想了解更多有关 WordPress 过滤挂钩的内容,请参阅《50个 WordPress 过滤挂钩》一文。

在WordPress中使用动作挂钩

定义动作挂钩只是最简单的一步,幸运的是,学会如何创建和使用动作挂钩也是非常简单的。首先,让我们来看看怎样将相关函数挂载到动作挂钩上,怎样创建新的动作挂钩,清除现有的挂钩和其他在 WordPress core中与动作挂钩相关的函数。

将一个函数挂载到一个动作挂钩上

其中最简单的函数也许就是 add_action():它可以将某个函数挂载到我们即将使用的动作挂钩上

  1. <?php
  2.  
  3. add_action( $hook_name, $function_name, $priority, $arguments );
  4.  
  5. ?>

让我们来看看这些参数意味着什么:

  • $hook_name 是所使用的动作挂钩的名称。
  • $function_name 是函数名。
  • $priority 是我们规定的一个整数,用来设置函数在此挂钩中的优先级别。
  • $arguments 是函数所使用的和动作挂钩同时所允许的参数个数。

让我们来看一个简单的例子:

  1. <?php
  2.  
  3. add_action( 'add_meta_boxes', 'my_function', 10, 2 );
  4.  
  5. function my_function( $post_type, $post ) {
  6.     // do stuff with $post_type and $post
  7. }
  8.  
  9. ?>

很简单,对吧?

从动作挂钩中清除原有函数

我们可以使用以下两个函数清除动作挂钩中的原有函数: remove_action() 和 remove_all_actions()

首先来看一看它们是如何使用的:

  1. <?php
  2.  
  3. // remove_action( $hook_name, $function_name, $priority );
  4. remove_action( 'login_enqueue_scripts', 'some_function', 10 );
  5.  
  6. // remove_all_actions( $hook_name, $priority );
  7. remove_all_actions( 'wp_enqueue_scripts', 10 );
  8.  
  9. ?>

remove_action() 有三个参数:挂钩名称、要清除的函数名和使用 add_action() 时设置的优先级别。 remove_all_actions() 函数则没有$function_name 参数,因为它会清除动作挂钩中的所有函数。

创建一个动作挂钩

如果你想要开发 WordPress插件或者主题的话,一个值得推荐的做法是在你的代码中创建一些挂钩,这样其他的开发人员就可以继续扩展你的插件和主题了。而要做到这一点,我们需要两个函数:do_action() 和 do_action_ref_array()。让我们来看看第一个函数是如何运作的:

  1. <?php
  2.  
  3. do_action( $hook_name, $arg1, $arg2, /* ... */ $argN );
  4.  
  5. /*
  6.  * Usage:
  7.  * 
  8.  * add_action( hook_name, my_function )
  9.  * 
  10.  * function my_function( $arg1, $arg2 ) {
  11.  *     // do stuff with $arg1, $arg2 and so on
  12.  * }
  13.  * 
  14.  */
  15.  
  16. ?>

正如你所看到的那样,这个函数实际上可以包含无限多的参数,你可以根据需要来定义任意多的参数。如果你想在一个数组中保存这些参数,那么你还需要使用第二个函数:

  1. <?php
  2.  
  3. $args = array( $arg1, $arg2, /* ... */ $argN );
  4.  
  5. do_action_ref_array( $hook_name, $args );
  6.  
  7. /*
  8.  * Usage:
  9.  * 
  10.  * add_action( hook_name, my_function )
  11.  * 
  12.  * function my_function( $args ) {
  13.  *     // do stuff with $args[0], $args[1] and so on
  14.  * }
  15.  * 
  16.  */
  17.  
  18. ?>

检索动作挂钩被调用的次数

如果你想知道一个动作挂钩被调用的次数,你可以使用一个简单方便的函数来统计:

  1. <?php
  2.  
  3. function tuts_foo() {
  4.     $action_count = did_action( 'some_action_name' );
  5.     if ( 1 === $action_count ) {
  6.         // run code if 'some_action_name' has been fired only once
  7.     }
  8. }
  9.  
  10. ?>

正如你看到的那样,这个函数中唯一的参数就是动作挂钩的命名。

检查是否存在指定的动作挂钩

假设你正在为一个流行的 WordPress 插件开发其他的扩展插件,你首先需要检查用户是否已经安装了这个 WordPress 插件。(毕竟,如果这个插件没有安装并激活的话,那么你后来开发的插件也将无法使用。)

为了进行这项检查,你可以使用 has_action() 函数以确定这个插件的动作挂钩是可以访问的:

  1. <?php
  2.  
  3. if( has_action( 'some_popular_plugin_action' ) {
  4.     add_action( 'some_popular_plugin_action', 'extension_to_the_some_popular_plugin' );
  5. } else {
  6.     wp_die( 'Sorry to kill your website but I need "Some Popular Plugin" to work with.' );
  7.     // CAUTION: This is a joke. Don't shut down a website because your plugin can't work with it.
  8. }
  9.  
  10. ?>

就像 did_action() 函数,has_action() 函数只有一个参数:动作挂钩的名称。

介绍50个 WordPress 动作挂钩的更多相关文章

  1. 黄聪:WordPress动作钩子函数add_action()、do_action()源码解析

    WordPress常用两种钩子,过滤钩子和动作钩子.过滤钩子相关函数及源码分析在上篇文章中完成,本篇主要分析动作钩子源码. 然而,在了解了动作钩子的源码后你会发现,动作钩子核心代码竟然跟过滤钩子差不多 ...

  2. WordPress插件制作教程(六): 插件函数之动作(Actions)函数

    这一篇为大家说一下WordPress插件函数吧,要制作插件,了解这些函数是非常有必要的 WordPress插件函数分为“动作”(Actions)和过滤器”(Filters),WordPress 使用这 ...

  3. 经典收藏 50个jQuery Mobile开发技巧集萃

    http://www.cnblogs.com/chu888chu888/archive/2011/11/10/2244181.html 1.Backbone移动实例 这是在Safari中运行的一款Ba ...

  4. (转)经典收藏 50个jQuery Mobile开发技巧集萃

    (原)http://www.cnblogs.com/chu888chu888/archive/2011/11/10/2244181.html 经典收藏 50个jQuery Mobile开发技巧集萃   ...

  5. 决定如何开发你的WordPress主题框架

    在本系列教程的第一部分,我介绍了不同类型的主题框架并解释了它们是如何工作的. 在你开始建立你的主题框架之前,你需要考虑它是如何工作的,以及它将会被用来做什么,这样你才能从一开始就找到最合适的开发途径. ...

  6. WordPress 主题框架是如何工作的

    主题框架可以说是无比强大的!对于非技术型的 WordPress 用户来说,主题框架使得建立一个独一无二并看起来像是运行一个量身定制的主题的网站成为可能,并且对于 WordPress 开发者来说,它们能 ...

  7. cocos2d-x实战 C++卷 学习笔记--第7章 动作、特效(一)

    前言: 介绍cocos2d-x中的动作.特效. 动作: 动作(action)包括基本动作和基本动作的组合,这些基本动作有缩放.移动.旋转等,而且这些动作变化的速度也可以设定. 动作类是 Action. ...

  8. wordpress教程之函数讲解

    wordpress函数收集 is_home() : 是否为主页is_single() : 是否为内容页(Post),   是否是单篇文章  is_page() : 是否为内容页(Page),   是否 ...

  9. (转)每位设计师都应该拥有的50个CSS代码片段

    原文地址:http://www.cnblogs.com/fengyuqing/archive/2013/06/15/css_50.html 面对每年如此多的 新趋势 ,保持行业的领先是个很困难问题. ...

随机推荐

  1. iOS开发:Swift多线程NSThread的使用

    一:创建线程,NSThread创建线程常用的三种方式: //1:手动创建启动 let thread:NSThread = NSThread(target: self, selector:"d ...

  2. Jqgrid入门-别具特色的Pager Bar (四)

    Pager Bar位于表格最下边.默认情况下,分为三部分.如图: 第一部分:导航按钮栏(Navigator) 第二部分:页码栏(Pager) 第三部分:记录信息栏(Record)         要实 ...

  3. java 访问器方法中对象引用的问题

    "注意不要编写返回引用可变对象的访问器方法".因为会破坏类的封装性,引用的内容可能会被改变,产生业务逻辑上的错误. 什么是可变对象? 先要搞清楚java中值传递和引用传递的问题,总结如下: 1.对象就 ...

  4. hdu 2059(dp)

    题意:容易理解... 思路:dp[i]表示乌龟到达第i个充电站时最少花费时间到第 i 个充电站后,从起点开始遍历到第 i-1 个充电站,得到最少花费时间 状态转移方程:dp[i]=min(dp[j]+ ...

  5. Linux+Apache+Tomcat集群配置

    参考: http://blog.csdn.net/bluishglc/article/details/6867358# http://andashu.blog.51cto.com/8673810/13 ...

  6. HDU5758 Explorer Bo 树形dp

    我是参考这一篇写的:http://blog.csdn.net/fsss_7/article/details/52049474 一点感想:dp[i][0]代表以这个点为根的且总叶子数为偶数个叶子的答案 ...

  7. UITextView 相关知识点

    1.得到UITextView的高度 - (CGRect)contentSizeRectForTextView:(UITextView *)textView { [textView.layoutMana ...

  8. 动态执行linq 语句 NLinq

    using Evaluant.NLinq.Memory;using System.Collections.Generic;using Evaluant.NLinq;using System.Colle ...

  9. Python pycurl

    常用方法: pycurl.Curl() #创建一个pycurl对象的方法 pycurl.Curl(pycurl.URL, http://www.google.com.hk) #设置要访问的URL py ...

  10. iOS学习网站及大牛网址(实时更新)

    iOS学习网站及大牛网址(实时更新) 学习网站 https://github.com/Tim9Liu9/TimLiu-iOS  自己总结的iOS.mac开源项目及库 https://github.co ...