文本是《50个 WordPress 过滤钩子(共7篇)》专题的第 5 篇。阅读本文前,建议先阅读前面的文章:
在本系列前面几个章节中,我们已经学习了 30 个WordPress过滤钩子,下面我们继续通过样例来学习下面的10个过滤钩子。
过滤默认的相册样式
WordPress 一般用[ gallery]这个简码加载预定义的CSS。你也可以通过use_default_gallery_style过滤钩子实现自定义。
样例:禁用默认样式
如果你已经在主题样式文件style.css中定义了相册样式,但又不想使用它,此时便可以用下列的代码禁用。
<?php
add_filter( 'use_default_gallery_style', '__return_false' );
?>
OK,现在WordPress便不会在[ gallery]简码中自动添加<style>标签了。
过滤附件URLs
在此我们使用名为wp_get_attachment_url()的过滤钩子。
样例:避免出现“内容混合”的警示
如果你的网站使用的是ssl加密方式,wp_get_attachment_url()函数默认会返回http的url而非https,因此会给访客“内容混合”的警示消息。下面的代码会屏蔽此类消息显示:
<?php
add_filter( 'wp_get_attachment_url', 'wp_get_attachment_url_example' );
function wp_get_attachment_url_example( $url ) {
$http = site_url( false, 'http' );
$https = site_url( false, 'https' );
if ( $_SERVER['HTTPS'] == 'on' )
return str_replace( $http, $https, $url );
else
return $url;
}
// Example source: http://codex.wordpress.org/Plugin_API/Filter_Reference/wp_get_attachment_url
?>
设置邮件的默认内容类型
wp_mail()函数默认邮件内容使用普通的text/plain作为文本类型,通过这个wp_mail_content_type过滤钩子,你可对其做出某些修改。
样例:在WordPress的电子邮件内容中使用HTML类型
如果你想在邮件中使用HTML类型,可以使用下列代码来实现:
<?php
add_filter( 'wp_mail_content_type', 'wp_mail_content_type_example' );
function wp_mail_content_type_example( $content_type ) {
return 'text/html';
}
?>
保存评论者的ip地址
WordPress 在数据库中会保留每一个评论者的ip地址,如果你想修改,可以使用这个pre_comment_user_ip过滤钩子。
样例:保存评论者的真实ip地址
如果评论者是通过代理服务器提交的评论,WordPress将记录代理服务器的ip而非其真实IP。其实真正的IP可以在HTTP头部的X-Forwarded-For信息中找到。下列的代码能实现提取真实的IP并将其保存在数据库中。
<?php
add_filter( 'pre_comment_user_ip', 'pre_comment_user_ip_example' );
function pre_comment_user_ip_example() {
$REMOTE_ADDR = $_SERVER['REMOTE_ADDR'];
if ( !empty( $_SERVER['X_FORWARDED_FOR'] ) ) {
$X_FORWARDED_FOR = explode( ',', $_SERVER['X_FORWARDED_FOR'] );
if ( !empty( $X_FORWARDED_FOR ) )
$REMOTE_ADDR = trim( $X_FORWARDED_FOR[0] );
} elseif( !empty( $_SERVER['HTTP_X_FORWARDED_FOR'] ) ) {
$HTTP_X_FORWARDED_FOR = explode( ',', $_SERVER['HTTP_X_FORWARDED_FOR'] );
if ( !empty( $HTTP_X_FORWARDED_FOR ) )
$REMOTE_ADDR = trim( $HTTP_X_FORWARDED_FOR[0] );
}
return preg_replace( '/[^0-9a-f:\., ]/si', '', $REMOTE_ADDR );
}
// Example source: https://codex.wordpress.org/Plugin_API/Filter_Reference/pre_comment_user_ip
?>
若你想了解更多的X-Forwarded-For HTTP头部信息知识,请访问维基百科http://en.wikipedia.org/wiki/X-Forwarded-For
修改文章的保存版本修订次数
你一定知道WordPress 中文章的“修订版本”的功能,若想修改版本修订次数,可以通过修改wp-config.php文件中的WP_POST_REVISIONS常量值来实现。
如果想修改其他文章类型的版本修订次数,则可以使用wp_revisions_to_keep过滤钩子。
样例:禁止某些特定文章类型使用“修订版本”功能
可以用$post变量来修改版本修订次数,在下面的代码中,自定义了指定文章类型为‘even’的版本修订次数,在应用中将其改为你自己的即可。
<?php
add_filter( 'wp_revisions_to_keep', 'wp_revisions_to_keep_example', 10, 2 );
function wp_revisions_to_keep_example( $num, $post ) {
if ( 'event' == $post->post_type ) {
return 0;
}
return $num;
}
// Example source: http://codex.wordpress.org/Plugin_API/Filter_Reference/wp_revisions_to_keep
?>
在过滤钩子中$post变量的具体用法可参考http://codex.wordpress.org/Class_Reference/WP_Post,若有了新的发现,别忘了留言与我们共同分享。
重写
简码
使用[ caption]简码可以简单地使用题注包裹图片,如果你想修改简码的显示输出,就可使用下列过滤钩子。
样例:用HTML5标记图像题注
HTML5 标准建议我们使用两个新的图片相关的标签:<figure> 或<figcaption> ,在下方的样例中,我们将重写标记:
<?php
add_filter( 'img_caption_shortcode', 'img_caption_shortcode_example', 10, 3 );
function img_caption_shortcode_example( $empty, $attr, $content ) {
$attr = shortcode_atts( array(
'id' => '',
'align' => 'alignnone',
'width' => '',
'caption' => ''
), $attr );
if ( 1 > (int) $attr['width'] || empty( $attr['caption'] ) ) {
return '';
}
if ( $attr['id'] ) {
$attr['id'] = 'id="' . esc_attr( $attr['id'] ) . '" ';
}
$figure_atts = $attr['id']
. ' class="caption ' . esc_attr( $attr['align'] )
. '" ' . 'style="max-width: ' . ( 10 + (int) $attr['width'] ) . 'px;"';
$output = '<figure ' . $figure_atts . '>';
$output .= do_shortcode( $content );
$output .= '<figcaption>' . $attr['caption'] . '</figcaption>';
$output .= '</figure>';
return $output;
}
// Example source: http://codex.wordpress.org/Plugin_API/Filter_Reference/img_caption_shortcode
?>
如果你不想使用<figure>标签的IDs, 可以随意修改上述代码.
添加文章CSS类名
在WordPress 开发中常使用body_class这个过滤钩子,还有个名为post_class的过滤钩子(函数)可以让你在文章中添加自定义的CSS 类。
样例:在循环中为第一篇文章添加特殊类
为循环中的第一篇文章添加一个特殊的类是个不错的例子,我们来看看具体是怎么实现的。
<?php
add_filter( 'post_class', 'post_class_example' );
function post_class_example( $classes ) {
global $wp_query;
if ( 0 == $wp_query->current_post ) {
$classes[] = 'first-post';
}
return $classes;
}
// Example source: http://www.billerickson.net/code/first-post-class/
?>
现在,就可以使用类 .first-post而不用担心因为使用 :first这个伪类而导致的不同浏览器兼容性问题了。
在附件中增加自定义字段
在WordPress 中,附件本质上类似于一种定制的、可扩展的文章类型,它们之间仅有细微区别。过滤钩子attachment_fields_to_edit可以让我们在上传或编辑附件的时候自定义一些操作。
样例:为上传的图片添加授权信息
例如有个摄影图片相关的博客,需要为博客中上传的每一张作为附件的图片添加授权许可信息。这里我们使用“actions”动作钩子,在附件中新增了一个“license”域输入框。
<?php
add_filter( 'attachment_fields_to_edit', 'attachment_fields_to_edit_example', 10, 2 );
function attachment_fields_to_edit_example( $form_fields, $post ) {
$field_value = get_post_meta( $post->ID, 'license', true );
$form_fields['license'] = array(
'value' => $field_value ? $field_value : '',
'label' => __( 'License' ),
'helps' => __( 'Specify the license type used for this image' )
);
return $form_fields;
}
add_action( 'edit_attachment', 'save_new_attachment_field' );
function save_new_attachment_field( $attachment_id ) {
$license = $_REQUEST['attachments'][$attachment_id]['license'];
if ( isset( $license ) ) {
update_post_meta( $attachment_id, 'license', $license );
}
}
// Example source: http://codex.wordpress.org/Plugin_API/Filter_Reference/attachment_fields_to_edit
?>
就这样,不需修改核心代码,我们就可以扩展WordPress的核心函数功能了。
改变自动摘要的字数长度
WordPress摘要默认清除HTML格式并截取前面的55个单词,若想对其做些许变化,可使用过滤钩子excerpt_length。
样例:改变自动摘要的字数长度
若想做个Pinterest 风格的页面布局,空间又有限,摘要字数只能限制在15个字,则可在函数中返回字符数,然后hook到这个过滤钩子
<?php
add_filter( 'excerpt_length', 'excerpt_length_example' );
function excerpt_length_example( $words ) {
return 15;
}
?>
很容易就实现了,是吧?
处理后台管理页面中的“批量操作”功能
在WordPress的后台管理页面中有类似文章、页面、用户、多媒体等栏目,你在选择完多个项目之后可进行一些批量操作。下面的过滤钩子可让我们对这个下拉菜单做些修改。
样例:禁用将文章移至回收站的批量操作
若你运营着一个新闻类的网站,对编辑人员意外将需要更新的文章移至回收站中感到很无奈,此时便可使用下方的代码来禁用批量移动文章到回收站的功能了。
<?php
add_filter( 'bulk_actions-edit-post', 'bulk_actions_edit_post_example' );
function bulk_actions_edit_post_example( $actions ) {
unset( $actions['trash'] );
return $actions;
}
?>
若你想了解更多过滤钩子中的类似$screenid的变量名称,可以参考官方“Admin Screen Reference @ Plugin API” 文档。
第四部分结语
在本文中我们完成了10个过滤钩子的学习,希望你喜欢并能从中学习到新的知识。请在留言区写下您的建议意见,当然也别忘了把你觉得好的文章分享给你的好友哦,下个教程我们再见。
原文出自:http://code.tutsplus.com/tutorials/50-filters-of-wordpress-filters-31-40–cms-21297
由 shanezx@WordPress大学 原创翻译,未经允许,禁止转载和采用本译文。
您已阅读完《50个 WordPress 过滤钩子(共7篇)》专题的第 5 篇。请继续阅读该专题下面的文章: