WordPress评论中的链接会自动转换为可点击的链接,某些情况下这对访客是友好的,更方便查看评论中引用的网站。但有时候评论者只是输入了一个示例链接,例如http://yourdomain.com/anything,这个被转换就有点恼人了。因此决定禁用评论中自动转换链接的功能。
解决方案
在主题的functions.php中添加如下代码remove_filter( 'comment_text', 'make_clickable', 9 );
非常简单对吗?但只是知道这个似乎意义不大,学习讲究举一反三,知道这样做的理由似乎更重要。
为什么链接被自动转换
禁用的方法很简单,但我喜欢弄清来龙去脉。先说一下为什么链接会被自动转换。
WordPress加载过程中会include一个叫做default-filters.php的文件,位于wp-includes/目录下,该文件包含WordPress默认添加的actions和filters,看一下这个文件,满眼的add_action或者add_filter。
在评论表单中,用comment_text()函数输出用户的评论,comment_text()函数提供了一个filter叫做comment_text,在comment_text()函数返回评论结果前过滤结果。WordPress默认向这个filter添加了哪些函数?打开default-filters.php看一下,发现添加了如下功能://将Wordpress更正为WordPress
add_filter( 'comment_text', 'capital_P_dangit', 31 );
//格式化特殊符号
add_filter( 'comment_text', 'wptexturize' );
//转换符号,例如将
变成
add_filter( 'comment_text', 'convert_chars' );
//将url自动变成可点击的链接,我们要找的东西
add_filter( 'comment_text', 'make_clickable', 9 );
//如其名字所说,将不完整的标签补全
add_filter( 'comment_text', 'force_balance_tags', 25 );
//将符号转换为表情
add_filter( 'comment_text', 'convert_smilies', 20 );
//自动添加
和
标签
add_filter( 'comment_text', 'wpautop', 30 );
WordPress将评论存入数据库时,是原封不动的存入的,例如用户输入
引用 小明的话数据库存入的内容和上面相同,标签结构是不完整的,当程序调用comment_text()函数输出评论内容时,数据需要被上面提到的7个函数过滤一遍,当被force_balance_tags()处理时,就会将标签补全,于是输出的结果是
引用 小明的话既然WordPress用add_filter添加了make_clickable功能,我们只需要用于其相反的remove_filter移除这个功能就可以了,于是就有了开头的解决方案。
remove_filter中的9代表什么?
添加filter时,9代表优先级,规定了所有添加到某个hook的函数的执行顺序,移除的时候也一样。想象一下add_filter会让一个函数进入队列排队,数字越大的排的越靠后,即执行越晚。当我们需要移除某个函数时,必须保证移除功能在添加功能之后执行,在该函数还没有添加的时候移除它,没有任何意义。
make_clickable函数位于wp-includes/formatting.php中,不仅将链接变成可点击的,而且会自动添加rel="nofollow"属性,如果你希望跟随某些链接,可以先移除默认的功能,然后写一个自己的功能加进去。
举一反三
这种remove_filter和add_filter的把戏可以用到很多地方,比如很多插件会用wp_enqueue_script和wp_enqueue_style添加自己的脚本和样式表,如果插件把脚本放到head中,可能会拖慢网页加载速度;有的插件自带的样式表只有几句话,单独存放成一个文件完全没必要,这些行为都会让你的head标签内容变长,对SEO也是有害的。你想制止这种行为,怎么办?
用上面提到的先remove再add的思想,只不过这次我们调用的是另外两对函数:wp_dequeue_style
wp_enqueue_style
wp_dequeue_script
wp_enqueue_script
例如,想将WP-PageNavi插件的样式表移除,将样式合并到主题的style.css中,可以在functions.php中如是说add_action('wp_print_styles', 'dequeue_stylesheets');
function dequeue_stylesheets() {
wp_dequeue_style('wp-pagenavi');
}
这样WP-PageNavi的样式表link就从head中消失了。
再举个移动脚本的例子,wp-codebox插件默认将脚本codebox.js放在head中,我希望将其挪到