WordPress wp_head()优化:去除不必要的元素标签(转)

最近笔者在采用wordpress建站的时候,发现页面会生成很多冗余的代码,有些东西其实我们用不到,而且没什么很大的作用,这些代码我找了半天也没找到源代码怎么删除,最终发现是wp_head() 这个方法输出的代码,那么要如何删除这些不必要的头部信息呢。 文章来自http://www.life134.com

去除wordpress头部不必要的元素标签 文章来自http://www.life134.com

完整的wordpress头部清理代码

  1. <?php
  2. //remove_action( ‘wp_head’, ‘wp_enqueue_scripts’, 1 );
  3. remove_action( ‘wp_head’, ‘feed_links’, 2 );
  4. remove_action( ‘wp_head’, ‘feed_links_extra’, 3 );
  5. remove_action( ‘wp_head’, ‘rsd_link’ );
  6. remove_action( ‘wp_head’, ‘wlwmanifest_link’ );
  7. remove_action( ‘wp_head’, ‘index_rel_link’ );
  8. remove_action( ‘wp_head’, ‘parent_post_rel_link’, 10, 0 );
  9. remove_action( ‘wp_head’, ‘start_post_rel_link’, 10, 0 );
  10. remove_action( ‘wp_head’, ‘adjacent_posts_rel_link_wp_head’, 10, 0 );
  11. //remove_action( ‘wp_head’, ‘locale_stylesheet’ );
  12. remove_action( ‘publish_future_post’, ‘check_and_publish_future_post’, 10, 1 );
  13. //remove_action( ‘wp_head’, ‘noindex’, 1 );
  14. //remove_action( ‘wp_head’, ‘wp_print_styles’, 8 );
  15. //remove_action( ‘wp_head’, ‘wp_print_head_scripts’, 9 );
  16. remove_action( ‘wp_head’, ‘wp_generator’ );
  17. //remove_action( ‘wp_head’, ‘rel_canonical’ );
  18. remove_action( ‘wp_footer’, ‘wp_print_footer_scripts’ );
  19. remove_action( ‘wp_head’, ‘wp_shortlink_wp_head’, 10, 0 );
  20. remove_action( ‘template_redirect’, ‘wp_shortlink_header’, 11, 0 );
  21. add_action(‘widgets_init’, ‘my_remove_recent_comments_style’);
  22. function my_remove_recent_comments_style() {
  23. global $wp_widget_factory;
  24. remove_action(‘wp_head’, array($wp_widget_factory->widgets[‘WP_Widget_Recent_Comments‘], ‘recent_comments_style’));
  25. }
  26. ?>
 文章来自http://www.life134.com 

把这段代码插入到主题的functions.php文件下,就可以清除WordPress头部很多的冗余信息。下面说说这些代码的具体意义是什么,以免删除某些你想保留的功能。

wp_head()函数

wp_head()是wordpress的一个非常重要的函数,基本上所有的主题在header.php这个文件里都会使用到这个函数,而且很多插 件为了在header上加点东西也会用到wp_head(),比如SEO的相关插件。不过在wp_head()出现的这个位置,会增加很多并不常用的代 码,如何删除呢?可以通过remove_action移除这些代码。

remove_action函数


函数原型:remove_action( $tag, $function_to_add, $priority, $accepted_args );

该函数移除一个附属于指定动作hook的函数。该方法可用来移除附属于特定动作hook的默认函数,并可能用其它函数取而代之。

重要:添加hook时的$function_to_remove 和$priority参数要能够相匹配,这样才可以移除hook。该原则也适用于过滤器和动作。移除失败时不进行警告提示。 文章来自http://www.life134.com

参数 文章来自http://www.life134.com

  • 1.$tag(字符串)(必需)将要被删除的函数所连接到的动作hook。默认值:None
  • 2.$function_to_remove(回调)(必需) 将要被删除函数的名称默认值:None
  • 3.$priority(整数)(可选)函数优先级(在函数最初连接时定义)默认值:10
  • 4.$accepted_args(整数)(必需)函数所接受参数的数量。默认值:1

返回值

(布尔值)函数是否被移除。 文章来自http://www.life134.com

  • 1.Ttue 函数被成功移除
  • 2.False函数未被移除

移除WordPress版本信息

在head区域,可以看到如下代码:

  1. <meta name="generator" content="WordPress 3.1.3" />

这是隐性显示的WordPress版本信息,默认添加。可以被黑客利用,攻击特定版本的WordPress漏洞。清除代码:

  1. remove_action( ‘wp_head’, ‘wp_generator’ );

移除离线编辑器开放接口

WordPress自动添加两行离线编辑器的开放接口

  1. <link rel="EditURI" type="application/rsd+xml" title="RSD" href="http://example.com/xmlrpc.php?rsd" />
  2. <link rel="wlwmanifest" type="application/wlwmanifest+xml" href="http://example.com/wp-includes/wlwmanifest.xml" />
 文章来自http://www.life134.com 

其中RSD是一个广义的接口,wlwmanifest是针对微软Live Writer编辑器的。如果你不需要离线编辑,可移除之。即便你需要使用离线编辑器,大部分时候也不需要这两行代码。Live Writer自己知道它们。保留这两行代码可能会留有安全隐患。清除代码:

  1. remove_action( ‘wp_head’, ‘rsd_link’ );
  2. remove_action( ‘wp_head’, ‘wlwmanifest_link’ );

移除前后文、第一篇文章、主页meta信息

WordPress把前后文、第一篇文章和主页链接全放在meta中。我认为于SEO帮助不大,反使得头部信息巨大。移除代码: 文章来自http://www.life134.com

  1. remove_action( ‘wp_head’, ‘index_rel_link’ ); // Removes the index link
  2. remove_action( ‘wp_head’, ‘parent_post_rel_link’, 10, 0 ); // Removes the prev link
  3. remove_action( ‘wp_head’, ‘start_post_rel_link’, 10, 0 ); // Removes the start link
  4. remove_action( ‘wp_head’, ‘adjacent_posts_rel_link_wp_head’, 10, 0 ); // Removes the relational links for the posts adjacent to the current post.
 文章来自http://www.life134.com 

移除Canonical标记

09年2月份,Google,Yahoo及Microsoft三大搜索引擎联合推出了一个旨在减少重复内容困扰的方法,这对于广大站长来说不啻是个好事情,不用再担心因为网站上有重复的内容而影响到网站页面的权重了。

造成重复内容的原因有很多,最常见的便是多个url地址指向了同一个页面,比如:wordpress平台下的一篇日志页面,包括了文章及评论内容。 每个评论都可以有个固定的链接地址,,如果有多个评论的话,则每条评论的链接都类似于上述格式,只是commentID号有所不同,这些链接其实都是指向 同一篇文章的。蜘蛛来爬时,便会依次爬行一遍,这篇文章下如有10条评论,则爬了10次相同的页面文章,相当于做了多次重复的工作,严重影响了抓取的效 率,及耗费了带宽。

重复内容造成的结果必然是蜘蛛不愿意来爬,不同的url指向同一个页面,也会影响到该页面的权重。通过canonical标签,能有效的避免这类问题。 文章来自http://www.life134.com

需要注意两点:

  • 1.允许指向不同的子域名,不允许指向其他域名
  • 2.canonical属性可以被传递
    即A页面声明B为权威链接,B声明C为权威网页,那么C就是A和B共同的首选权威版本

如果你的WP版本在2.9之前,需要通过插件(上面已经提到)或者手工 Hack 主题的 header.php 文件来使得博客支持。

  1. <link rel="canonical" href="<?php get_permalink()?>" />
 文章来自http://www.life134.com 

在 WordPress 2.9 发布之后,WordPress 已经默认支持这一标签了,我们无需做任何动作,主题就支持这一标签。这对于文章固定链接的更改很有帮助,可以增加对搜索引擎的友好度。但是如果你觉得这个标签对你无用,也可以移除之:

  1. remove_action( ‘wp_head’, ‘rel_canonical’ );

移除feed

HTML中通过<link rel="alternate" type="application/rss+xml" title="feed名" href="http://example.com/feed/" />来指定博客feed。可以被浏览器检测到,然后被读者订阅。

如果你不想添加feed,或者想使用烧制的feed(如FeedSky或者Feedburner烧制的feed),可以移除之。

  1. remove_action( ‘wp_head’, ‘feed_links’, 2 );//文章和评论feed
  2. remove_action( ‘wp_head’, ‘feed_links_extra’, 3 ); //分类等feed
 文章来自http://www.life134.com 

如果用的烧制的feed,然后还可以再手动添加feed地址。

时间: 2025-01-15 19:14:58

WordPress wp_head()优化:去除不必要的元素标签(转)的相关文章

WordPress 性能优化:为什么我的博客比你的快

WordPress 很慢? 很多博主都会感觉 WordPress 很慢?作为全世界最常用的建站和博客系统 WordPress 来说,在性能设计上肯定不会有太大的问题,WordPress 开发团队也肯定也考虑到这个问题. 那么 WordPress 效率问题主要是出在哪里呢?根据我多年 WordPress 建站和维护的经验,很多性能的问题都是 WordPress 使用不当造成的,比如安装太多效率低下的插件,使用代码质量低下的主题,没有正确处理 WordPress 的缓存等等,所以提高 WordPre

去除数组中重复元素

问题 统计一个一维数组中的各个元素的个数,然后删除多出来的重复元素,并输出结果. 例如:[1,2,2,2,3,3,3,3,3]-->[1,2,3] 解决思路 将重复元素的列表中的重复元素进行统计,并将统计结果放在dictionary中,key为元素,value为该元素的个数 然后通过for获取key,得到一个新的列表,就是没有重复元素的列表 解决(Python) #!/usr/bin/env python #coding:utf-8 def count_element(one_list): el

js去除字符串中所有html标签及&amp;nbsp符号

近日在做项目的时候,经常会在页面上处理一些数据.结果发现自己js掌握的并不是很好.那就在这里记录js的点点滴滴吧. 1. 去除字符串中的 html 标签 function delHtmlTag(str){ return str.replace(/<[^>]+>/g,""); } var str = "<span style='display:none;'>This is test</span><br/>"; st

Html5学习笔记1 元素 标签 属性

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>HTML5学习笔记</title> </head> <body bgcolor="#90ee90"> 1.Html5的元素<br/><br/> 元素指的是从開始标签到结束标签的全部代码<

html行内元素标签

元素分类--内联元素 在html中,<span>.<a>.<label>. <strong> 和<em>就是典型的内联元素(行内元素)(inline)元素.当然块状元素也可以通过代码display:inline将元素设置为内联元素.如下代码就是将块状元素div转换为内联元素,从而使 div 元素具有内联元素特点. div{ display:inline; } ...... <div>我要变成内联元素</div> 内联元素特

第六十节,文本元素标签

文本元素标签 <b></b>表示关键字和产品名称如:<b>查看效果</b> 效果:加粗 查看效果 <strong></strong>表示重要的文字 如:<strong>查看效果</strong> 效果:加粗 查看效果 <br>强制换行如:<br>查看<br>效果效果:在浏览器显示换行 查看效果  <wbr>安全换行,一般只用于英文如:<wbr>查看&l

HTML 5的革新之一:语义化标签一节元素标签。

摘至于:<HTML 5的革新——语义化标签(一)> 在HTML 5出来之前,我们用div来表示页面章节,但是这些div都没有实际意义.(即使我们用css样式的id和class形容这块内容的意义).这些标签只是我们提供给浏览器的指令,只是定义一个网页的某些部分.但现在,那些之前没“意义”的标签因为因为html5的出现消失了,这就是我们平时说的“语义”. 看下图没有用div标签来布局 html5的布局 嗯,如上图那个页面结构没有一个div,都是采用html5语义标签(用哪些标签,关键取决于你的设计

去除重复嵌套的html标签函数

去除重复嵌套的html标签 1 function strip_multi_tags($str, $tag = 'div'){ 2 preg_match_all('/<'.$tag.'>|<\/'.$tag.'>/is', $str, $matched); 3 $divs = $matched[0]; 4 $pairs = array(); 5 foreach($divs as $k => $v){ 6 if($v == '<'.$tag.'>'){ 7 $begi

Jquery 获取元素标签名称

Jquery的获取元素标签名称的方法: 1.$( this ).get(0).tagName 2.$( this )[0].tagName 3.$( this ).prop("tagName") 4.$( this ).prop("nodeName") 原文地址:https://www.cnblogs.com/queende7/p/8669051.html