php 自动点击 链接,禁止评论自动转换URL为可点击的链接

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中,我希望将其挪到

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值