找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 2051|回复: 0
打印 上一主题 下一主题

WordPress开发中自定义菜单的相关PHP函数使用简介

[复制链接]

2617

主题

2617

帖子

7789

积分

论坛元老

Rank: 8Rank: 8

积分
7789
跳转到指定楼层
楼主
发表于 2018-2-14 05:39:56 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            函数意义
wp_nav_menu ()
自定义菜单显示函数
register_nav_menu ()
自定义菜单注册函数 – 单数
register_nav_menus ()
自定义菜单注册函数 – 复数 (很蛋疼的一个复数形式)
以下举例均用 register_nav_menus () 这个复数形式,以免混淆。
使用位置
register_nav_menus ()
function.php 文件中,用于注册自定义菜单在后台的代码调用名称和后台显示名称。
wp_nav_menu ()
主题任意你想调用自定义菜单的位置。
使用方法
注册4个菜单更正:3个菜单(困了,老出错。)
register_nav_menus( array(
'nav1' => 'n1',
//nav1 为菜单名称(调用的时候用)
//n1 为显示名称 , 后台选菜单的时候用

'nav2' => 'n2',

'nav3' => 'n3'

));
然后去你的后台 =》 外观 =》 菜单 里面看下,
基本上你就明白了,
要是不明白,
那你就再看一下,嘿嘿~
主题你想要显示自定义导航的位置添加以下代码。

//调用 nav1 的菜单
'nav1' ) ); ?>

//调用 nav2 的菜单
'nav2' ) ); ?>
然后就可以到后台去添加一个菜单了,(名称最好是名称或中文。更正:最好是英文。)
你可以设定这个菜单里面显示什么,不显示什么,甚至可以设置导航的层级内容,很方便的说。
过滤掉自定义菜单中无用的CLASS值
在 WordPress 的自定义菜单的输出中,菜单中每一个子元素都有一个很长的 class 值,虽然从外观上看不出什么异样来,但从代码上看确实让人心里很难受,其实要过滤掉这些 class 值有很多方法,今天来讲一下通过挂载过滤器 (filter),去除那些我们不想要的class。
在 WordPress 3.5.0 以后的版本中将取消友情链接功能,并以自定义菜单功能实现,这个是后话。
我们在输出自定义菜单的时候,为了让我们更好的控制自定义样式, WordPress 会默认给我们菜单的子元素输出很多个 class 的值,就像下面这样。
如何过滤之,让我们的网页源代码变得简洁、易读呢?
在你的functions.php里面加入
function filter_nav_menu_css_class ($classes){
//想要通过的class值
$do_class_name = array('current-menu-item');
$outPut = array_intersect($do_class_name,$classes);
array_filter( $classes );
return $outPut;
};
add_filter('nav_menu_css_class','filter_nav_menu_css_class');
这里将 current-menu-item 这个值保留主要是为了辨别当前页面。
其实,
还有其他方法去过滤输出的 class 值的,
比如说控制 Walker_Nav_Menu 这个类来精确控制自定义菜单的输出,
但因为比较麻烦所以在这里先不提,其实 Walker_Nav_Menu 这个类可以完成更多我们需要的功能。
总结 – 需注意
自定义菜单式在 WordPress 3.0 后才引入的一个功能概念,有点类似于之前的小工具,不过自定义菜单更倾向于导航用途,但因为新功能的中文翻译、流传较慢,再加上这个功能只要是主题成型的爱折腾的博主一般不会在导航方面折腾,所以大家还一直不了解,甚至都出现了错误教程满天飞得局面,在这里希望有的博主在发表博文的时候不要以转载为主,就算是转载一些主要功能请具体测试一下,以免误导新人。
需注意:
后台设置中如果没有给自定义导航里面设定菜单的话,那wp会为没有设定菜单的导航里自动添加所有页面为导航,这是一个蛋疼的缺省,所以如果这个导航我们不想显示的话,你最好能在后天设定一个空的菜单,然后给不想显示的导航添加这个菜单,这样自定义导航就不会显示了。
            
            
您可能感兴趣的文章:
  • WordPress中用于获取搜索表单的PHP函数使用解析
  • WordPress开发中用于获取近期文章的PHP函数使用解析
  • WordPress中调试缩略图的相关PHP函数使用解析
  • WordPress主题制作中自定义头部的相关PHP函数解析
  • 是 WordPress 让 PHP 更流行了 而不是框架
  • 编写PHP脚本清除WordPress头部冗余代码的方法讲解
  • 解析WordPress中控制用户登陆和判断用户登陆的PHP函数
  • 详解WordPress中用于更新和获取用户选项数据的PHP函数
  • 调用WordPress函数统计文章访问量及PHP原生计数器的实现
  • 在CentOS系统上从零开始搭建WordPress博客的全流程记录
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端