2009-08-19

10 Useful WordPress Hook Hacks

Hooks are very useful in WordPress. They allow you to “hook” a
custom function to an existing function, which allows you to modify
WordPress’ functionality without editing core files. In this article,
we have compiled 10 extremely useful ready-to-use WordPress hooks,
along with examples and coding explanations.



Learn more about the Smashing Book!


Want to learn more about CSS coding and web design? Take a look at our upcoming Smashing Book ($23.90 $29.90, available worldwide). Pre-order now with 20% discount!




What Is A Hook?


To achieve a particular effect on a WordPress blog, you have to
modify how WordPress works. Some of these modifications are made to
what WordPress developers call “core files,” files required by
WordPress to work properly.


But modifying core files is always a bad idea. It may create a
security loophole. Also, you will have lost the modification when you
upgrade your WordPress installation.


Still, developers need to overwrite some of WordPress’ functionality, which is why WordPress provides the Plugin API.


Hooks are one of the main building blocks of WordPress plug-ins.
Almost every plug-in uses a hook to overwrite WordPress’ core
functionality.


How to Use Hooks on Your WordPress Blog


Unless you’re writing a plug-in, you would write hooks in the functions.php file. This file is located in the wp-content/themes/yourtheme directory.


A hook, as you would expect, “hooks” one function to another. For
example, you could write a custom function and attach it to one of
WordPress’ core functions:


add_action ( 'publish_post', 'myCustomFunction' );

In this example, we hook our own custom function to WordPress’ publish-post function, which means that every time WordPress executes the publish-post function, it will also execute this hooked function.


Of course, we can also remove hooks using the remove_action() function:


remove_action ( 'publish_post', 'myCustomFunction' );


Hooks resources:



1. Disable WordPress’ Automatic Formatting


Screenshot


The problem.

You have probably noticed that, by default, WordPress converts normal
quotes to “curly” quotes, and makes other little formatting changes
when a post is displayed.


This is very cool for people who publish normal content, but anyone
who uses their blog to discuss code will be annoyed because, when
pasted in a text editor, code with curly quotes returns syntax errors.


The solution.

Simply paste the following code in your functions.php file:


function my_formatter($content) {<br />	$new_content = '';<br />	$pattern_full = '{(\[raw\].*?\[/raw\])}is';<br />	$pattern_contents = '{\[raw\](.*?)\[/raw\]}is';<br />	$pieces = preg_split($pattern_full, $content, -1, PREG_SPLIT_DELIM_CAPTURE);<br /><br />	foreach ($pieces as $piece) {<br />		if (preg_match($pattern_contents, $piece, $matches)) {<br />			$new_content .= $matches[1];<br />		} else {<br />			$new_content .= wptexturize(wpautop($piece));<br />		}<br />	}<br /><br />	return $new_content;<br />}<br /><br />remove_filter('the_content', 'wpautop');<br />remove_filter('the_content', 'wptexturize');<br /><br />add_filter('the_content', 'my_formatter', 99);<br />

Once that’s done, you can use the [raw] shortcode in your posts:


[raw]This text will not be automatically formatted.[/raw]

Code explanation.

Our first step here was to create a function that uses a regular expression to find the [raw] shortcode in your posts’ content.


Then we hook our my_formatter() function to WordPress’ the_content() function, which means that my_formatter() will now be automatically called every time the_content() is called.


To remove the automatic formatting, we use the remove_filter() function, which lets you delete a hook on a specific function.


Source:



2. Detect The Visitor’s Browser Using A Hook


Screenshot


The problem.

Cross-browser compatibility is probably the most common problem in Web
development. You will save yourself a lot of headaches if you are able
to detect the browsers that people use to visit your website and then
create a custom class wrapped in the body
tag. Few people are aware of it, but WordPress can already detect
browsers, and a few global variables are available for us to use.


The solution.

Nothing hard here: just paste the code below in your functions.php file, then save the file and you’re done!


<?php<br />add_filter('body_class','browser_body_class');<br />function browser_body_class($classes) {<br />	global $is_lynx, $is_gecko, $is_IE, $is_opera, $is_NS4, $is_safari, $is_chrome, $is_iphone;<br /><br />	if($is_lynx) $classes[] = 'lynx';<br />	elseif($is_gecko) $classes[] = 'gecko';<br />	elseif($is_opera) $classes[] = 'opera';<br />	elseif($is_NS4) $classes[] = 'ns4';<br />	elseif($is_safari) $classes[] = 'safari';<br />	elseif($is_chrome) $classes[] = 'chrome';<br />	elseif($is_IE) $classes[] = 'ie';<br />	else $classes[] = 'unknown';<br /><br />	if($is_iphone) $classes[] = 'iphone';<br />	return $classes;<br />}<br />?><br />

Once you have saved the file, the function will automatically add a CSS class to the body tag, as shown in the example below:


<body class="home blog logged-in safari">

Code explanation.

WordPress has global variables that return true if a visitor is using a particular browser. If the visitor’s browser is Google Chrome, the $is_chrome variable will return true. This is why we create the browser_body_class() function, which returns the name of the visitor’s browser. Once that’s done, we just hook the function to WordPress’ body_class() function.


Sources:



3. Define Default Text In TinyMCE


Screenshot


The problem.

Many bloggers almost always use the same layout for their blog posts.
Posts on my own blog WpRecipes.com are always displayed the same way:
some text, some code and then some more text.


What about saving time by forcing tinyMCE (WordPress’ visual editor) to display default text?


The solution.

Once again, hooks are the solution. Just open your functions.php file, paste the code and let the hooks work their magic!


<?php<br />add_filter('default_content', 'my_editor_content');<br /><br />function my_editor_content( $content ) {<br />	$content = "If you enjoyed this post, make sure to subscribe to my rss feed.";<br />	return $content;<br />}<br />?><br />

Code explanation.

This code is powerful, and yet the method is so simple. Just create a
function that returns the desired text (in this example, we have
defined some simple text that asks readers to subscribe to the blog’s
RSS feed), and hook the function to WordPress’ default_content() function. That’s it.


Sources:



4. Insert Content Automatically After Each Post


Screenshot


The problem.

Most blogs use the single.php template to insert some text, images or ads just after a post. Sure, this can be done by opening single.php and pasting the desired text after the the_content() function. But the text won’t show up in your RSS feed? Hooks and the technique described below solve this problem.


The solution.

One again, simply paste the code below in the functions.php file of your theme. That’s it.


function insertFootNote($content) {<br />        if(!is_feed() && !is_home()) {<br />                $content.= "<div class='subscribe'>";<br />                $content.= "<h4>Enjoyed this article?</h4>";<br />                $content.= "<p>Subscribe to our  <a href='http://feeds2.feedburner.com/WpRecipes'>RSS feed</a> and never miss a recipe!</p>";<br />                $content.= "</div>";<br />        }<br />        return $content;<br />}<br />add_filter ('the_content', 'insertFootNote');<br />

Code explanation.

The purpose of the insertFootNote() function is pretty simple: it simply concatenates text of your choice to the $content variable, which contains your post’s content.


Then, our insertFootNote() function is hooked to the the_content() function, and it is automatically called every time the the_content is called. Using this function is basically the same as typing in the text at the end of each post.


Notice the (!is_feed) condition on line 2, which
prevents the text from being inserted in the RSS feed. If you want the
text to appear in your RSS feed, replace line 2 with the following:


if (!is_home()) {<br />

Sources:



5. Disable The “Please Update Now” Message On WordPress Dashboard


Screenshot


The problem.

Your dashboard automatically lets you know when a new version of
WordPress is released by inserting a message at the top of admin pages.
This is definitely a good thing, because updating gives your blog the
latest functions and security fixes. But if the blog is a client
project, letting the client control updates may not be a good idea.


The solution.

Just paste these four lines of code in your functions.php file:


if (!current_user_can('edit_users')) {<br />  add_action( 'init', create_function( '$a', "remove_action( 'init', 'wp_version_check' );" ), 2 );<br />  add_filter( 'pre_option_update_core', create_function( '$a', "return null;" ) );<br />}<br />

Once you save functions.php, you won’t see the message on the dashboard.


Code explanation.

The first thing we do here is make sure the current user has sufficient
administrative rights to update WordPress. Once we do that, we just
create two hooks to overwrite the automatic check for updates and
message display.


Sources:



6. Disable WordPress From Auto-Saving Posts


Screenshot
Photo by thatcanadiangirl


The problem.

As you type a post in the dashboard, WordPress periodically saves the
content. This is a useful feature, but sometimes you may want to
disable it.


The solution.

To disable WordPress’ auto-saving functionality, simply open the functions.php file and paste the following function:


function disableAutoSave(){<br />    wp_deregister_script('autosave');<br />}<br />add_action( 'wp_print_scripts', 'disableAutoSave' );<br />

Code explanation.

Again, nothing hard about this code. We simply create an action (on line 4) and hook the disableAutoSave() function that we created on line 1 to WordPress’ wp_print_scripts().


The result is that our disableAutoSave() function is called every time WordPress executes wp_print_scripts(). This way, we make sure the auto-save functionality is disabled.


Sources:



7. Prevent Duplicate Content On Comment Pages


Screenshot


The problem.

Duplicate content is an SEO problem for many websites. It can also be a
problem for your WordPress blog if you don’t apply a few tricks.


Introduced in version 2.7, paged comments is a great addition to
WordPress because it lets bloggers split comments into multiple pages.
The only problem, again, is the risk of duplicate content.


Let’s use the new rel="canonical" attribute to prevent duplicate content in paged comments.


The solution.

Simply paste the following code in your function.php file:


function canonical_for_comments() {<br />	global $cpage, $post;<br />	if ( $cpage > 1 ) :<br />		echo "\n";<br />	  	echo "<link rel='canonical' href='";<br />	  	echo get_permalink( $post->ID );<br />	  	echo "' />\n";<br />	 endif;<br />}<br /><br />add_action( 'wp_head', 'canonical_for_comments' );<br />

Code explanation.

First, we create a function to add the rel="canonical" attribute to comment pages, except page 1. Then we hook this function to WordPress’ wp_head() function. As simple as that!


Sources:



8. Get Entire Post Or Page In A PHP Variable


Screenshot


The problem.

Being able to get the entire current post or page as a PHP variable is
definitely a good thing. You could, for example, replace parts of the
content using the str_replace() PHP function, and much more.


The solution.

Once again, nothing hard. Just paste the following in your function.php file.


function callback($buffer) {<br />	// modify buffer here, and then return the updated code<br />	return $buffer;<br />}<br /><br />function buffer_start() {<br />	ob_start("callback");<br />}<br /><br />function buffer_end() {<br />	ob_end_flush();<br />}<br /><br />add_action('wp_head', 'buffer_start');<br />add_action('wp_footer', 'buffer_end');<br />

Code explanation.

To achieve this hack, we need three functions:


  • callback(): this function returns the whole page as a variable called $buffer. You can modify it before returning it by using regular expressions, for example.
  • buffer_start(): this function simply starts the buffer. It is hooked to WordPress’ wp_head() function.
  • buffer_end(): this function clears the buffer. It is hooked to WordPress’ wp_footer() function.

Once we have our function, we just hook it to existing WordPress functions.


Sources:



9. Use Hooks And Cron To Schedule Events


Screenshot


The problem.

You probably already know that WordPress can schedule events. For
example, it can publish posts at preset dates and times. Using hooks
and wp-cron, we can easily schedule our own events. In this example, we will get our WordPress blog to send us an email once hourly.


The solution.

Paste the following code block in the functions.php file of your theme.


if (!wp_next_scheduled('my_task_hook')) {<br />	wp_schedule_event( time(), 'hourly', 'my_task_hook' );<br />}<br /><br />add_action( 'my_task_hook', 'my_task_function' ); <br /><br />function my_task_function() {<br />	wp_mail('you@yoursite.com', 'Automatic email', 'Hello, this is an automatically scheduled email from WordPress.');<br />}<br />

Code explanation.

The first thing we did, of course, was create a function that performs
the desired action. In this example, the function is called my_task_function() and it just sends an email to the specified email address.


To schedule an event, we have to use the wp_schedule_event() function. The last argument has to be a hook, which is why we hook our my_task_function() function to my_task_hook.


Sources:



10. List All Hooked Functions


Screenshot


The problem.

When things go wrong, listing all hooked functions can be very useful for debugging.


The solution.

As with the others, this code has to be pasted in your functions.php file. When you have finished debugging, don’t forget to remove the code from functions.php, or else the debugging message will continue to appear.


function list_hooked_functions($tag=false){<br /> global $wp_filter;<br /> if ($tag) {<br />  $hook[$tag]=$wp_filter[$tag];<br />  if (!is_array($hook[$tag])) {<br />  trigger_error("Nothing found for '$tag' hook", E_USER_WARNING);<br />  return;<br />  }<br /> }<br /> else {<br />  $hook=$wp_filter;<br />  ksort($hook);<br /> }<br /> echo '<pre>';<br /> foreach($hook as $tag => $priority){<br />  echo "<br />&gt;&gt;&gt;&gt;&gt;\t<strong>$tag</strong><br />";<br />  ksort($priority);<br />  foreach($priority as $priority => $function){<br />  echo $priority;<br />  foreach($function as $name => $properties) echo "\t$name<br />";<br />  }<br /> }<br /> echo '</pre>';<br /> return;<br />}<br />

Once that’s done, simply call the list_hooked_functions() function, as shown below, to print all hooked WordPress functions on your screen.


list_hooked_functions();

Code explanation.

If no hook name is provided to the function as an argument, then hooks are printed to the screen using the global variable $wp_filter. Alternatively, you can list one particular hook by passing its name as an attribute:


list_hooked_functions('wp_head');

Sources:



Related posts


You may be interested in the following related posts:



About the Author


This guest post was written by Jean-Baptiste Jung, a 27-year-old WordPress expert from Belgium. He blogs about WordPress at WpRecipes, about practical Web development tips at Cats Who Code and about Photoshop and Web design at PsdVibe. You can stay in touch with Jean by following him on Twitter.

精选文章

旧手机变废为宝|五分钟安装Ollama跑开源大模型 - 开发调优 - LINUX DO

旧手机变废为宝|五分钟安装Ollama跑开源大模型 - 开发调优 - LINUX DO 在开始之前,请你先准备好一台旧Android手机以及特殊的网络环境。 1.安装Termux 2.更新软件包及依赖 pkg update && pkg upgrade 3.安...