10个query_posts使用技巧

发布时间:2020-05-06

10个query_posts使用技巧Query_posts语句是wordpress最实用的语句之一。 正是在query_posts的作用下,wordpress的Loop循环才能够调用并显示所有文章内容。 Query_posts的魅力在于,它可以根据你的要求,通过各种各样的方式灵活地检索并过滤日志或页面。

你可以用query_posts进行简单的文章抓取,可以只抓取一篇,也可以抓取上百篇。 而说到复杂点的用法,你甚至可以利用query_posts来查询某一分类目录下某个作者发表的、带有某个标签的特定数量文章等。

下面介绍的是一些更实用的用法。

1.注意事项

首先要注意的是,使用query_posts的最好方法….就是不要用它。 Query_posts中说到: query_posts函数仅用于修改主页循环(Loop),而不是一种在页面上生成次级循环的手段。如果你希望在主循环外另外生成循环,应该新建独立的 WP_Query对象,用这些对象生成循环。在主循环外的循环上使用query_posts会导致主循环运行偏差,并可能在页面上显示出你不希望看到的内 容。

最恰当的方法是使用query查询类。

  1. <?php
  2. $query = ‘posts_per_page=10’;
  3. $queryObject = new WP_Query($query);
  4. // The Loop…
  5. if ($queryObject->have_posts()) {
  6.     while ($queryObject->have_posts()) {
  7.         $queryObject->the_post();
  8.         the_title();
  9.         the_content();
  10.     }
  11. }
  12. ?>

2. 不同调用方法

传统的文章调用方法是以查询字符串形式传递query_posts参数(如variable1=value1&variable2=value2&…),不过后来有了新方法——用数组来设置查询参数。

  1. <?php
  2. // GOOD
  3. // select 10 posts from category 1
  4. $query = ‘posts_per_page=10&cat=1’;
  5. $queryObject = new WP_Query($query);
  6. // The Loop…
  7. // BETTER
  8. $query = array (
  9.     ‘posts_per_page’ => 10,
  10.     ‘cat’ => 1
  11. );
  12. $queryObject = new WP_Query($query);
  13. // The Loop…
  14. ?>

当然,使用哪种方法完全由个人习惯决定,不过我认为用数组更为方便,原因如下:

便于阅读,可以利用if语句更轻松地给数组添加条件,以动态生成查询一些查询参数(某些使用频率较低的参数,如分类参数和标签参数)需要被传递数组
你可以将函数调用以参数的形式传递

3. 关于日志顺序

默认情况下wordpress日志是按日期顺序排列的,这也是大多数人的需求,不过如果能更改默认的排列顺序那就更好了。 例如你可以随意调用几篇日志,让它们显示在侧边栏。 wordpress 2.9引入了以评论的数量多寡给文章排序的功能,这样就可以更方便地向访客显示最受欢迎的文章….不过这里为了使用query_posts,我们假设一下不使用wordpress的这个功能。

  1. <?php
  2. // select posts ordered by comment_count
  3. $query = ‘orderby=comment_count’;
  4. $queryObject = new WP_Query($query);
  5. // The Loop…
  6. ?>

4. Meta值

Post meta函数的实用性也很强, 我们可以利用下面的代码来显示最受欢迎的文章:

  1. <?php
  2. // grab posts by post count ordered in descending order (most votes first)
  3. $query = ‘meta_key=vote_count&orderby=meta_value&order=DESC’;
  4. $queryObject = new WP_Query($query);
  5. // The Loop…
  6. ?>

5. 日志? 页面? 附件?

你可以按文章类型调用自己想要的日志、页面或附件。 对附件的调用可能是最有趣但同时被使用频率也是最低的一个。 利用下面的代码(与上文中提到的顺序参数),你就可以根据自己的喜好在网站上显示各种媒体文件了:

  1. <?php
  2. // grab 1 random attachment
  3. $query = ‘post_type=attachment&orderby=rand&posts_per_page=1’;
  4. $queryObject = new WP_Query($query);
  5. // The Loop…
  6. ?>

6. 置顶文章

wordpress在 2.7版本中引入了文章置顶功能。 这使用户选定的文章能够不受时间的排序标准,总是显示在文章列表的最上方。 实现文章置顶的标准操作是,将这些文章添加到所返回数据列表的开始部分。 你可能需要对置顶文章过滤器函数进行以下操作:

默认情况——调用最先添加的置顶文章

只调用置顶文章(适用于杂志型主题)

按正常情况调用文章,忽略文章的置顶状态

要调用所有置顶文章:

  1. <?php
  2. $query = array(
  3.     ‘post__in’=>get_option(‘sticky_posts’)
  4. );
  5. $queryObject = new WP_Query($query);
  6. // The Loop…
  7. ?>

要忽略置顶文章——让所有文章按正常排序方式显示:

  1. <?php
  2. $query = array(
  3.     ‘post__not_in’ => get_option(‘sticky_posts’)
  4. );
  5. $queryObject = new WP_Query($query);
  6. // The Loop…
  7. ?>

7. 抓取所有文章

你可以用几种不同的方法在网站地图和存档页等需要显示所有已发布文章的地方调用所有文章。 要调用所有已发布的文章,可以使用下面的这段代码:

  1. <?php
  2. // showposts is the traditional way of doing it, but it’s now deprecated so could be removed at any time
  3. // there are still lots of themes that use showposts (including my own) so it’s worth switching over as soon as you can just in case
  4. $query = ‘showposts=-1’;
  5. $queryObject = new WP_Query($query);
  6. // The Loop…
  7. // the new way to do it
  8. $query = ‘posts_per_page=-1’;
  9. $queryObject = new WP_Query($query);
  10. // The Loop…
  11. // must admit I have never tried this myself but according to the documentation it will work 10个query_posts使用技巧
  12. $query = ‘nopaging=true’;
  13. $queryObject = new WP_Query($query);
  14. // The Loop…
  15. ?>

8. 钩子(hooks)和过滤器(filter)

Query_posts函数一个鲜有人知的功能就是,你可以用它勾入已生成的查询。 这种行为可能有些冒险,不过实用价值很高。 wordpress有一些可以用来修改查询要素的过滤器(filter)函数。
根据对wordpress filter函数的介绍,可以用在文章查询和调用上的filter包括:

post_limits

应用于查询的LIMIT语句,该语句可返回日志数组

posts_distinct

允许插件将DISTINCTROW语句加入查询,该查询可返回日志数组

posts_groupby

应用于查询的GROUP BY语句,该语句可返回日志数组(通常情况下该数组为空)

posts_join_paged

应用于查询的JOIN语句。在计算出分页后,该查询返回日志列表(分页并不影响JOIN语句,因此该函数相当于posts_join)

posts_orderby

应用于查询的ORDER BY语句,该语句可返回日志数组

posts_request

在执行查询前,应用于将返回日志数组的整个SQL查询

posts_where_paged

应用于查询的WHERE语句。在计算出分页后,该查询返回日志数组(分页并不影响WHERE语句,因此该函数相当于posts_where)

posts_join

应用于查询的JOIN语句,该语句可返回日志数组 该过滤器函数与post_where函数一并为JOIN语句添加了一个数据库表。

posts_where

应用于查询的WHERE语句,该语句可返回日志数组

Query_posts参数数量极多且复杂,大多数人没有必要了解这些。但有时如果你想用数字型meta值来为一次查询排序,却发现meta值是字符串字段类型的(即,查询的顺序是1, 10, 11, 2, 23, 3,而你希望是按数字大小来排序:1,2,3,10,11,23)。 这时你可以用下面的代码达到效果:

  1. add_filter (‘posts_orderby’, ‘bm_featureHomeFilterOrder’);
  2. function bm_featureHomeFilterOrder ($order = ) {
  3.     global $wpdb;
  4.     $field = $wpdb->postmeta . ‘.meta_value’;
  5.     $order = str_replace($field, ‘CAST(‘ . $field . ‘ AS UNSIGNED)’, $order);
  6.     return $order;
  7. }

9. 文章回转

文章回转功能使用户可以运行“wordpress循环”后重设主循环,然后再重新运行主循环。 调用文章回转也很容易。

  1. <?php rewind_posts(); ?>

那么要使用它你需要:

  1. <?php
  2. $query = ‘posts_per_page=10’;
  3. $queryObject = new WP_Query($query);
  4. // The Loop…
  5. rewind_posts();
  6. // The Loop…
  7. ?>

10. 不显示某些文章(隐藏重复内容)

最后这个方法曾经在WebLogToolsCollection上出现过。 其原理是当用户在某一个页面上使用多个wordpress循环时,用代码阻止重复内容被链接。例如,当你的网站首页显示了最新发表的日志后会继续显示分类,如果隐藏重复内容,分类下将隐藏已经显示的最新发表的日志, 从而让更多内容显示在主页上。这是WebLogToolsCollection上的原始代码:

  1. $bmIgnorePosts = array();
  2. /**
  3.  * add a post id to the ignore list for future query_posts
  4.  */
  5. function bm_ignorePost ($id) {
  6.     if (!is_page()) {
  7.         global $bmIgnorePosts;
  8.         $bmIgnorePosts[] = $id;
  9.     }
  10. }
  11. /**
  12.  * reset the ignore list
  13.  */
  14. function bm_ignorePostReset () {
  15.     global $bmIgnorePosts;
  16.     $bmIgnorePosts = array();
  17. }
  18. /**
  19.  * remove the posts from query_posts
  20.  */
  21. function bm_postStrip ($where) {
  22.     global $bmIgnorePosts$wpdb;
  23.     if (count($bmIgnorePosts) > 0) {
  24.         $where .= ‘ AND ‘ . $wpdb->posts . ‘.ID NOT IN(‘ . implode (‘,’, $bmIgnorePosts) . ‘) ‘;
  25.     }
  26.     return $where;
  27. }
  28. add_filter (‘posts_where’, ‘bm_postStrip’);

下面是改进后的:

  1. <?php
  2. // set the query
  3. $query = ‘posts_per_page=10’;
  4. // loop 1 – display most recent 10 posts
  5. $queryObject = new WP_Query($query);
  6. if ($queryObject->have_posts()) {
  7.     while ($queryObject->have_posts()) {
  8.         bm_ignorePost($queryPost->post->ID);
  9.         $queryObject->the_post();
  10.         the_title();
  11.         the_content();
  12.     }
  13. }
  14. // loop 2 – same query, get the next 10 posts
  15. $queryObject = new WP_Query($query);
  16. if ($queryObject->have_posts()) {
  17.     while ($queryObject->have_posts()) {
  18.         bm_ignorePost($queryPost->post->ID);
  19.         $queryObject->the_post();
  20.         the_title();
  21.         the_content();
  22.     }
  23. }
  24. ?>

原文:10 wordpress query_posts tips you probably don’t know

大熊wordpress凭借多年的wordpress企业主题制作经验,坚持以“为用户而生的wordpress主题”为宗旨,累计为2000多家客户提供品质wordpress建站服务,得到了客户的一致好评。我们一直用心对待每一个客户,我们坚信:“善待客户,将会成为终身客户”。大熊wordpress能坚持多年,是因为我们一直诚信。我们明码标价(wordpress做网站需要多少钱),从不忽悠任何客户,我们的报价宗旨:“拒绝暴利,只保留合理的利润”。如果您有网站建设、网站改版、网站维护等方面的需求,请立即咨询右侧在线客服或拨打咨询热线:18324743309,我们会详细为你一一解答你心中的疑难。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

相关文章

写给所有做网站的朋友的一封信

写给所有做网站的朋友的一封信

现在就开始执行“1+N”互联网推广和没有开始执行的人,一两天看不出任何区别; 一两个月看来差异也是微乎其微的;但在2-5年的长远时间来看的时候,你的高质量询盘不断增加,你的互联网资产已经建立完成,对手已经很难匹敌,现在你看到这段文字的时候就是最好的开始,现在就是最好的时候,马上开始“1+N”体系的整体互联网推广吧,我们和你一起,开创互联网大未来!

点击查看详情

准备开启WordPress网站建设推广?

我们相信高端漂亮的网站不应该是昂贵的,这就是wordpress对每个人都是免费的原因
wordpress建站免费入门,并提供价格合理的wordpress建站套餐。