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


Posted in PHP onJanuary 05, 2016

函数意义
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 的菜单
<?php wp_nav_menu( array( 'theme_location' => 'nav1' ) ); ?>
 
//调用 nav2 的菜单
<?php wp_nav_menu( array( 'theme_location' => 'nav2' ) ); ?>

然后就可以到后台去添加一个菜单了,(名称最好是名称或中文。更正:最好是英文。)
你可以设定这个菜单里面显示什么,不显示什么,甚至可以设置导航的层级内容,很方便的说。

过滤掉自定义菜单中无用的CLASS值
在 WordPress 的自定义菜单的输出中,菜单中每一个子元素都有一个很长的 class 值,虽然从外观上看不出什么异样来,但从代码上看确实让人心里很难受,其实要过滤掉这些 class 值有很多方法,今天来讲一下通过挂载过滤器 (filter),去除那些我们不想要的class。
在 WordPress 3.5.0 以后的版本中将取消友情链接功能,并以自定义菜单功能实现,这个是后话。
我们在输出自定义菜单的时候,为了让我们更好的控制自定义样式, WordPress 会默认给我们菜单的子元素输出很多个 class 的值,就像下面这样。

<li id="menu-item-19" class="menu-item menu-item-type-post_type menu-item-object-page menu-item-19">

如何过滤之,让我们的网页源代码变得简洁、易读呢?

在你的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会为没有设定菜单的导航里自动添加所有页面为导航,这是一个蛋疼的缺省,所以如果这个导航我们不想显示的话,你最好能在后天设定一个空的菜单,然后给不想显示的导航添加这个菜单,这样自定义导航就不会显示了。

PHP 相关文章推荐
PHP4在WinXP下IIS和Apache2服务器上的安装实例
Oct 09 PHP
一个ubbcode的函数,速度很快.
Oct 09 PHP
PHP 远程文件管理,可以给表格排序,遍历目录,时间排序
Aug 07 PHP
打造超酷的PHP数据饼图效果实现代码
Nov 23 PHP
php中使用DOM类读取XML文件的实现代码
Dec 14 PHP
thinkphp实现多语言功能(语言包)
Mar 04 PHP
typecho插件编写教程(五):核心代码
May 28 PHP
PHP计算加权平均数的方法
Jul 16 PHP
PHP使用正则表达式获取微博中的话题和对象名
Jul 18 PHP
PHP实现递归复制整个文件夹的类实例
Aug 03 PHP
PHP实现生成带背景的图形验证码功能
Oct 03 PHP
PHP二维数组分页2种实现方法解析
Jul 09 PHP
PHP使用Pear发送邮件(Windows环境)
Jan 05 #PHP
WordPress中用于获取搜索表单的PHP函数使用解析
Jan 05 #PHP
在WordPress中使用wp_count_posts函数来统计文章数量
Jan 05 #PHP
详解WordPress中调用评论模板和循环输出评论的PHP函数
Jan 05 #PHP
简单的php+mysql聊天室实现方法(附源码)
Jan 05 #PHP
基于PHP实现简单的随机抽奖小程序
Jan 05 #PHP
详解WordPress开发中的get_post与get_posts函数使用
Jan 04 #PHP
You might like
PHP依赖倒置(Dependency Injection)代码实例
2014/10/11 PHP
PHP实现递归复制整个文件夹的类实例
2015/08/03 PHP
smarty中改进truncate使其支持中文的方法
2016/05/30 PHP
php实现生成带二维码图片并强制下载功能
2018/02/24 PHP
javascript基本语法分析说明
2008/06/15 Javascript
Javascript 事件流和事件绑定
2009/07/16 Javascript
js function定义函数使用心得
2010/04/15 Javascript
使用js在页面中绘制表格核心代码
2013/09/16 Javascript
javascript遍历控件实例详细解析
2014/01/10 Javascript
javaScript的函数对象的声明详解
2015/02/06 Javascript
JQuery EasyUI的使用
2016/02/24 Javascript
JS中setTimeout的巧妙用法前端函数节流
2016/03/24 Javascript
javascript学习之json入门
2016/12/22 Javascript
jQuery实现在新增加的元素上添加事件方法案例分析
2017/02/09 Javascript
JS库之Particles.js中文开发手册及参数详解
2017/09/13 Javascript
ES6解构赋值的功能与用途实例分析
2017/10/31 Javascript
JavaScript面向对象核心知识与概念归纳整理
2020/05/09 Javascript
[42:52]Optic vs Serenity 2018国际邀请赛淘汰赛BO3 第二场 8.22
2018/08/23 DOTA
python批量同步web服务器代码核心程序
2014/09/01 Python
用Python进行一些简单的自然语言处理的教程
2015/03/31 Python
python Django批量导入数据
2016/03/25 Python
Django集成搜索引擎Elasticserach的方法示例
2019/06/04 Python
python循环嵌套的多种使用方法解析
2019/11/29 Python
PyCharm无法引用自身项目解决方式
2020/02/12 Python
python+django+selenium搭建简易自动化测试
2020/08/19 Python
Python浮点型(float)运算结果不正确的解决方案
2020/09/22 Python
加拿大快时尚零售商:Ardene
2018/02/14 全球购物
应届生法律求职信
2013/10/22 职场文书
餐饮业会计岗位职责
2013/12/19 职场文书
个人贷款担保书
2014/04/01 职场文书
初中优秀班集体申报材料
2014/05/01 职场文书
质监局领导班子对照检查材料思想汇报
2014/09/27 职场文书
党的群众路线教育实践活动个人整改措施范文
2014/11/04 职场文书
2015年中秋节演讲稿
2015/03/20 职场文书
联谊活动总结范文
2015/05/09 职场文书
SpringDataJPA实体类关系映射配置方式
2021/12/06 Java/Android