WordPress主题制做导航的N种方法

在WordPress主 题制做中,导航菜单的制做算是一个重点,已经写好导航菜单的HTML代码,放在WordPress主题中如何动态调用呢?本文将给你介绍几种编写PHP代 码动态实现导航的方法,本文也将只侧重于动态代码的开发,不会教你如何编写HTML、CSS和Javascript来实现华丽的导航菜单。php

WP 3.0自定义菜单的制做
WordPress 3.0以后的版本开始支持自定义动态菜单,所谓的动态菜单,也就是容许用户自行决定将哪些项目添加到导航菜单中,进入WordPress的管理后台 – 外观 – 菜单栏目,经过拖拉相应的栏目,便可建立本身的菜单。这对于WordPress主题开发者和使用者来讲,都是皆大欢喜的事情。要想实现自定义菜单,须要用 到的函数是wp_nav_menu(),给这个函数传递一些参数就能够输出自定义菜单菜单,下面简单讲讲如何使用使用这个函数。css

首先,在主题目录下的functions.php的 之间,添加如下菜单注册代码,这样你就能够在主题文件中使用wp_nav_menu函数了:前端

// This theme uses wp_nav_menu() in one location.
register_nav_menus();

接着咱们在主题的导航栏处调用wp_nav_menu(),便可输出导航菜单HTML代码:数据库

  <?php 
    // 列出顶部导航菜单,菜单名称为mymenu,只列出一级菜单
    wp_nav_menu( array( 'menu' => 'mymenu', 'depth' => 1) );
?>

以上代码输出的HTML代码形式以下:数组

<div class="menu-menu-container">
    <ul class="menu" id="menu-menu">
        <li class="..." id="menu-item-1"><a href="...">首页</a></li>
        <li class="..." id="menu-item-2"><a href="...">分类A</a></li>
        ...
    </ul>
</div>

这里列出的 li 项为你在后台 – 外观 – 菜单添加的栏目,若是你尚未在后台添加菜单,导航栏将列出全部页面。另外,wp_nav_menu会为每一个 li 添加class,不一样的class标记这个菜单项的属性,如当前打开的是某个文章页面,分类A 就是这篇文章所属的分类,那么 分类A 所在的 li 将会以下代码所示:ide

<li class="menu-item menu-item-type-taxonomy current-post-ancestor current-menu-parent current-post-parent menu-item-5" id="menu-item-2"><a href="...">分类A</a></li>

若是是在首页,那么首页的菜单项的 li 可能会以下所示:函数

<li class="menu-item menu-item-type-custom current-menu-item current_page_item menu-item-home menu-item-4" id="menu-item-1"><a href="..">首页</a></li>

从这些class的名称就知道它们的做用,经过给这些class添加css属性,能够达到如高亮当前导航菜单的目的,如将当前菜单连接定义成红色:post

.current-post-ancestor a, .current-menu-parent a, .current-menu-item a, .current_page_item a {
    color: red;
}

好了,WordPress 3.0的自定义菜单的调用就是这么简单。wp_nav_menu还有不少参数,如自定义 ul 节点、ul 父节点的id和class的参数等等,详情请看官方文档。网站

很是规导航栏的制做
以上提到的两种方式,都是使用WordPress自带的函数来实现,他们输入的HTML代码也都是限定好的,就是使用 ul li 的形式来构建菜单列表:如:spa

<ul>
    <li class="..">...</li>
    <li class="..">...</li>
</ul>

若是主题的前端代码不是你写的,并且导航栏的代码写得很龟毛,这根本不是上面的WordPress标准的 ul 导航栏形式,以下面的代码:

<dl>
    <dt><strong>标题</strong></dt>
    <dd><a target="_blank" title="#" href="#">菜单A</a></dd>
    <dd><a target="_blank" title="#" href="#">菜单B</a></dd>
</dl>

重写前端代码?我想谁都不肯意这样作,那怎么办呢?还有,若是导航栏不使用分类和页面,也不让使用自定义菜单,那怎么办?在实际的应用中,咱们还会遇到各类各样且稀奇古怪的需求,请看下文:

1、使用get_terms()来获取分类列表
使用get_terms()能够获取你的文章分类、连接分类和自定义分类等,给get_terms()传递相应的参数能够给你返回一个对象数组,这个数组就是你想要的全部分类,如下是get_terms()的函数原型:

<?php get_terms( $taxonomies, $args ) ?>

$taxonomies:
该参数是你想要获取的分类类别,可选值包括:”category”,”link_category”,”my_taxonomy”,他们分别表明文章分类、连接分类以及你自定义的分类,其中my_taxonomy是你自定义的分类名称。

$args:
该参数是分类的筛选参数,用于控制获取你要获取的分类,包括你想要获取多少个分类、如何排序、父分类以及是否输出空的分类等,具体请参考 WordPress官方文档:Function Reference/get terms,或者参考中文的简要翻译:经常使用函数-get_terms()

下面是一个该函数的使用示例,这里将显示一个全部文章分类的

    • ..

..

形式的无序列表,固然咱们能够把它当作菜单:

<ul id="menu">      
<?php
    // 获取分类
    $terms = get_terms('category', 'orderby=name&hide_empty=0' );
 
    // 获取到的分类数量
    $count = count($terms);
    if($count > 0){
        // 循环输出全部分类信息
        foreach ($terms as $term) {
            echo '<li><a href="'.get_term_link($term, $term->slug).'" title="'.$term->name.'">'.$term->name.'</a></li>';
        }
    }
?>      
</ul>

get_terms()函数返回一个对象数组$terms,咱们首先判断这个数组是否为空,为空说明并无获取到任何分类,若是不为空那么你就能够输出分 类了。$terms的每一个数组项就是一个对象,部分对象属性的意义如:slug:分类缩略名,name:分类名,term_id:分类id。如以上代码所 示,你能够经过$term->name来获取对象的属性值。

2、使用读数据库的方式获取分类列表
若是你了解WordPress的数据库,能够发现WordPress的分类信息都存储在wp_terms和wp_term_taxonomy这两个表 中,wp_terms存储基本信息(包括文章分类、文章标签和连接分类等),wp_term_taxonomy用于存储进一步描述(用于存储描述、区分分 类和标签等)。咱们可使用SQL来从这两个表中获取咱们想要的分类列表:

<ul id="menu">      
<?php 
    $cats = $wpdb->get_results("SELECT {$wpdb->prefix}terms.term_id, name
                            FROM {$wpdb->prefix}term_taxonomy, {$wpdb->prefix}terms
                            WHERE {$wpdb->prefix}term_taxonomy.term_id = {$wpdb->prefix}terms.term_id
                            AND taxonomy = 'category'");
 
    if($cats) {
        foreach($cats as $cat) {
            echo '<li><a href="'.get_category_link($cat->term_id).'" title="'.$cat->name.'">'.$cat->name.'</a></li>';
        }
    }
?>      
</ul>

3、如何获取当前分类的id
有些时候咱们须要制做一个子导航,如http://www.nashowgroup.com/?p=58&lang=zh左边的人力资源导航,这 个导航能够是任意项目,如当前分类下的子分类或者当前分类下的文章等。那么首要问题就是,如何获取当前分类的id,这样才能够进行下一步的动做。

在分类页获取当前分类的id:

if ( is_category() ) {
    $cat_id = get_query_var('cat');
}

在文章页获取该文章的第一个分类:

$cats = get_the_category();
if($cats)
    $cat_id = $cats[0]->cat_ID;

4、子导航的制做
上面咱们讲解了如何获取当前分类的id,下面咱们来说讲如何制做子导航。首先,咱们来制做一个当前分类下子分类的子导航,这里用到wp_list_categories()来列出子分类,固然你能够用我前面介绍的两种方法来获取分类。:

<ul>
<?php
// 这里咱们用到上面获取到的$cat_id,获取该分类下的全部子分类
wp_list_categories('orderby=name&hide_empty=0&child_of=' . $cat_id);
?> 
</ul>

若是你的网站规模比较小,一个分类下的文章也很少,那么你能够在子导航中列出这个分类下的全部文章:

<ul>
    <?php
        global $wp_query;
 
        $query = array ( 'cat' => $cat_id, 'orderby' => title, 'order'=> ASC ); 
        $queryObject = new WP_Query($query); 
 
        if ($queryObject->have_posts()) :
            while ($queryObject->have_posts()) :
                $queryObject->the_post();
    ?>
    <li><a <?php if($post->ID == $wp_query->post->ID) echo 'class="chose"'; ?> href="<?php the_permalink() ?>"><?php the_title(); ?></a></li>
    <?php endwhile; wp_reset_postdata(); endif; ?>
</ul>

以上代码中用到了WP_Query来获取文章列表,该对象的使用方法,能够参考WordPress的官方文档:Class Reference/WP Query和Function Reference/query posts。class=”chose”用于高亮当前文章的菜单项,css规则你能够本身定义。
5、页面page的获取
WordPress的页面page能够经过wp_list_pages()来列出,不过这个函数输出的HTML都是固定的,若是你想要自定义这些HTML,可使用get_pages()来获取页面列表,代码示例以下:

<ul id="menu">
$mypages = get_pages();
 
if(count($mypages) > 0) {
    foreach($mypages as $page) {
        echo '<li><a href="'.get_page_link($page->ID).'" title="'.$page->post_title.'">'.$page->post_title.'</a></li>';
    }
}
else {
    echo '<li><a href="#">没有页面</a></li>';
}
</ul>
相关文章
相关标签/搜索