在利用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;
?>
有点复杂吧?加油,好好研究研究先~
免责声明: 本网站所发布的一切资源均来自于会员发布以及互联网收集,不代表本站立场,仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则一切后果请用户自负;依据WordPress GPL开源许可协议分享,如有侵犯到您的权益,请联系我们。