一,WordPress 使用 register_nav_menus() 设置菜单位置
导航菜单注册函数 register_nav_menus()
在主题的 functions.php 中添加:
if (function_exists('register_nav_menus')) { register_nav_menus(array( 'header_main' => __('顶部菜单'), 'footer_bottom' => __('底部菜单') )); }
上面注册了两个菜单位置,其中 ‘header_main’ 和 ‘footer_bottom’ 分别是这两个菜单的“键key”,后面的值是菜单的标题,会在 “外观->菜单->管理位置” 显示出来。
二,使用 wp_nav_menu() 生成菜单
使用的时候,指定菜单名称即可:
$nav_str = wp_nav_menu( array(
'theme_location' => 'footer_bottom', //[保留]用于在调用导航菜单时指定注册过的某一个导航菜单名,如果没有指定,则显示第一个
'menu' => 'footer_bottom', //[可删]使用导航菜单的名称调用菜单,可以是 id, slug, name (按顺序匹配的) 。
'container' => false, //[可删]最外层容器标签名
'container_class' => '',//[可删]最外层容器class名
'container_id' => '',//[可删]最外层容器id值
'menu_class' => 'footer-link-container', //[可删]ul 节点的 class 属性值
'menu_id' => '', //[可删]ul 节点的 id 属性值
'echo' => false, //[可删]确定直接显示导航菜单还是返回 HTML 片段,如果想将导航的代码作为赋值使用,可设置为false
'fallback_cb' => 'wp_page_menu', //[可删]备用的导航菜单函数,用于没有在后台设置导航时调用
'before' => '', //[可删]显示在导航a标签之前
'after' => '', //[可删]显示在导航a标签之后
'link_before' => '', //[可删]显示在导航链接名之前
'link_after' => '', //[可删]显示在导航链接名之后
'items_wrap' => '<ul id="%1$s" class="%2$s">%3$s</ul>', //[可删]使用字符串替换修改ul的class
'depth' => 0, //[可删]显示菜单的深度, 当数值为0时显示所有深度的菜单,-1所有菜单平级显示
'walker' => '' //[可删]自定义的遍历对象,调用一个对象定义显示导航菜单
));
echo str_replace('sub-menu', 'select', $nav_str);
三,使用 Walker_Nav_Menu 类创建自定义分类
声明:本站所有文章,如无特殊说明或标注,均为原创。