删除WordPress导航菜单多余ID和Class

2021-05-22 0 1,542 百度已收录

使用Wordpress程序建站少不了用到官方提供的菜单功效,对于一个爱折腾的WEB前段兴趣者来说那不能控的css选择器着实看着头疼,如下面的这段使用默认菜单功效天生的代码前段html代码当中泛起了多个id和class选择器,然则这些我们比一定全都能用到,于是就发生了一系列的多余代码。

在讲删除WordPress导航菜单多余ID和Class之前,我们先领会下WordPress增添模板菜单方式,在functions.php文件加上以下代码:

  1. if(function_exists('register_nav_menus')){
  2. register_nav_menus(
  3. array(
  4. 'header-menu' => __( '菜单名字A' ),
  5. 'footer-menu' => __( '菜单名字B' ),
  6. 'sider-menu' => __('菜单名字C')
  7. )
  8. );
  9. }

最简朴的挪用方式,前台加上下面代码:

  1. <?php wp_nav_menu(); ?>

也可以对这个菜单举行更多的控制,代码如下:

  1. <?php wp_nav_menu(
  2. array(
  3. 'theme_location'  => '' //指定显示的导航名,若是没有设置,则显示第一个
  4. 'menu'            => 'header-menu',
  5. 'container'       => 'nav', //最外层容器标署名
  6. 'container_class' => 'primary', //最外层容器class名
  7. 'container_id'    => '',//最外层容器id值
  8. 'menu_class'      => 'sf-menu', //ul标签class
  9. 'menu_id'         => 'topnav',//ul标签id
  10. 'echo'            => true,//是否打印,默认是true,若是想将导航的代码作为赋值使用,可设置为false
  11. 'fallback_cb'     => 'wp_page_menu',//备用的导航菜单函数,用于没有在后台设置导航时挪用
  12. 'before'          => '',//显示在导航a标签之前
  13. 'after'           => '',//显示在导航a标签之后
  14. 'link_before'     => '',//显示在导航链接名之后
  15. 'link_after'      => '',//显示在导航链接名之前
  16. 'items_wrap'      => '<ul id="%1$s">%3$s</ul>',
  17. 'depth'           => 0,////显示的菜单层数,默认0,0是显示所有层
  18. 'walker'          => ''// //挪用一个工具界说显示导航菜单 )); 
  19. ?>

在使用wp_nav_menu() 添加菜单,会输出许多CSS选择器,好比下面的代码:

  1. <li id="menu-item-6" class="menu-item menu-item-type-custom menu-item-object-custom current-menu-item current_page_item menu-item-home menu-item-6"><a href="/">WPMAKER</a></li>
  2. <li id="menu-item-13" class="menu-item menu-item-type-taxonomy menu-item-object-category menu-item-13"><a href="/news">WordPress资讯</a></li>
  3. <li id="menu-item-8" class="menu-item menu-item-type-taxonomy menu-item-object-category menu-item-8"><a href="/themes">WordPress主题</a></li>

上面这段代码就是用默认的菜单功效天生其中我只用到了menu-item 像id=”menu-item-13″ class=”menu-item menu-item-type-taxonomy menu-item-object-category menu-item-13″这些都是没用的,今天我就把去除多余css选择的的代码分享给人人,代码异常简朴行使wordpress的过滤器来删除这些没有的代码,可以将下面的代码添加到主题的 functions.php,移除所有的css选择器:

  1. /**
  2.  * 移除菜单的多余CSS选择器
  3.  */
  4. add_filter('nav_menu_css_class', 'my_css_attributes_filter', 100, 1);
  5. add_filter('nav_menu_item_id', 'my_css_attributes_filter', 100, 1);
  6. add_filter('page_css_class', 'my_css_attributes_filter', 100, 1);
  7. function my_css_attributes_filter($var) {
  8. 	return is_array($var) ? array() : '';
  9. }

输出效果如下,够精简了吧:

  1. <li><a href="/">WPMAKER</a></li>
  2. <li><a href="/news">WordPress资讯</a></li>
  3. <li><a href="/themes">WordPress主题</a></li>

不外,你可能要思量到界说当前菜单的某些样式,好比高亮显示当前菜单,那你就需要保留一些CSS选择器,才气界说当前菜单。常用的当前菜单的选择器有以下4个:

  • current-post-ancestor
  • current-menu-ancestor
  • current-menu-item
  • current-menu-parent
  1. /**
  2.  * 移除菜单的多余CSS选择器
  3.  */
  4. add_filter('nav_menu_css_class', 'my_css_attributes_filter', 100, 1);
  5. add_filter('nav_menu_item_id', 'my_css_attributes_filter', 100, 1);
  6. add_filter('page_css_class', 'my_css_attributes_filter', 100, 1);
  7. function my_css_attributes_filter($var) {
  8. 	return is_array($var) ? array_intersect($var, array('current-menu-item','current-post-ancestor','current-menu-ancestor','current-menu-parent')) : '';
  9. }
收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

1. 本站所有资源来源于用户上传和网络,因此不包含技术服务请大家谅解!如有侵权请邮件联系客服!3308869544
2. 本站不保证所提供下载的资源的准确性、安全性和完整性,资源仅供下载学习之用!如有链接无法下载、失效或广告,请联系客服处理,有奖励!
3. 您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容资源!如用于商业或者非法用途,与本站无关,一切后果请用户自负!
4. 如果您也有好的资源或教程,您可以投稿发布,成功分享后有猫币奖励和额外收入!

主题镇 WP教程 删除WordPress导航菜单多余ID和Class https://zhutizhen.com/14691.html

永远为用户服务的镇长!

常见问题
  • 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。
查看详情
  • 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或联络我们。
查看详情

相关文章