在利用wordpress制作CMS主题时,经常性地需要在页面某区块显示指定分类下的日志。
想实现这样的功能需求,可利用的方法有很多,包括query_posts函数、$wpdb全局变量、WP_Query类等等。


假设条件:分类ID:61 分类名称:技术前端 ,需要获取10条记录。


1、利用query_posts()函数
query_posts()是wordpress用来显示内容的最容易的方法之一(对应的还有一个get_posts),它可以通过各种灵活的方式检索或过滤你所需要的内容。

代码如下:

<?php
//The args
$args = 'cat=61&posts_per_page=10';
 
// The Query
query_posts( $args );
 
// The Loop
while ( have_posts() ) : the_post();
    echo '<li>';
    the_title();
    echo '</li>';
endwhile;
 
// Reset Query 重置查询数据
wp_reset_query();
 
?>

简单吧,这样就可以实现自由调用指定分类下的日志了。query_posts函数虽好用,但在使用该函数时,我们仍需要注意和尽量减少使用该函数的频率。


“如果我们不得不用到query_posts(),必须确保每次使用query_posts()后同时执行wp_reset_query()。这就是为什么我在上面的代码中加上了wp_reset_query()的原因。

另外,大多数使用wordpress的朋友们,可能都对wp-pagenavi这个插件不再陌生。这是作为辅助分页的插件成为很多wper的常用工具之一。其作者在自己的博客中,分析并强调了部分朋友在分页时会出现数据差异情况的原因,并提出了正确使用query_posts()函数的方法。

所以这里是使用 query_posts() 使分页工作的正确方法:

假设你有这样的事情:

query_posts('cat=8');

或者像这样:

query_posts( array( 'cat' => 8 ) );

您只需要传递主查询中的“分页”查询变量:

query_posts( array( 'cat' => 8, 'paged' => get_query_var('paged') ) );

如果这不起作用,您还可以尝试传递“页面”查询变量:

query_posts( array( 'cat' => 8, 'paged' => get_query_var('page') ) );

综合以上几点,加上易维护性的目的,我们重新来理一下代码:

<?php
    //The args
    $args = array(
        'cat'   => 61,
        'posts_per_page'    => 10,
        'paged'             => get_query_var('page') //如果需要分页,则加上这一句
    );
 
    // The Query
    query_posts( $args );
 
    // The Loop
    while ( have_posts() ) : the_post();
        echo '<li>';
        the_title();
        echo '</li>';
    endwhile;
 
    // Reset Query
    wp_reset_query();
 
?>

2、WP_Query类
WP_Query类被设定用来处理wordpress众多复杂的数据库处理,未来一段时间都将被提倡的使用方法之一。
按我个人的习惯和对wordpress的浅显认识,建议放弃烂用query_posts(),而改用WP_Query().尽管看上去有一点点烦。
仍以上面的需求为例,列代码如下:

<?php
    //The args
    $args = array(
        'cat'   => 61,
        'posts_per_page'    => 10,
    );
 
    // The Result
    $tech = new WP_Query( $args );
 
    if ( $tech -> have_posts() ) {
 
        // The Loop
        while ( $tech -> have_posts() ) : $tech ->the_post();
            echo '<li>';
            the_title();
            echo '</li>';
        endwhile;
 
    }else {
        echo 'no posts in current category!';
    }
?>

代码略加完善;不难看出,这样独立来调用数据,即安全易维护,又比较明晰;

以上两种方式中,$args所具有的内定参数,包括category__in, category__not_in, post__in, post__not_in等等可以至官方文档,作进一步了解.

http://codex.wordpress.org/Class_Reference/WP_Query#Parameters

3、$wpdb全局变量
$wpdb作为wordpress数据库类的引用,是无论皮肤制作或插件开发人员必须要强加掌握的内容之一。在Smashing Magazine中,”WordPress Essentials: Interacting With The WordPress Database“重点讲解了有关$wpdb的几点应用;
有了Daniel Pataki的讲解,作为一个业余爱好者,也有种蠢蠢欲动的冲动了。示例代码:

<?php
 
    $tech_posts = $wpdb->get_results( 
        SELECT DISTINCT     $wpdb->posts.*
        FROM                $wpdb->posts
        INNER JOIN          $wpdb->term_relationships
                            ON $wpdb->posts.ID = $wpdb->term_relationships.object_id
        WHERE               $wpdb->term_relationships.term_taxonomy_id IN (61)
        ORDER BY            $wpdb->posts.post_date DESC
        LIMIT               0,10
    ); 
 
    if ( $tech_posts ) :
        foreach( $tech_posts as $key => $tech ) {
            echo '<li>';
            echo $tech->post_title;
            echo '</li>';         
        }
    endif;
 
?>

有点复杂吧?加油,好好研究研究先~

发表回复

后才能评论