wordpress中的文章,默认是按发表时间排序的,从参数来看,默认的值是按照post_date来排列文章。也就是说,如果一篇文章发表于半年之前,而作者某天发现有几个位置表述有点不太确切,稍微改动了一下,那么这篇文章就又会被展现到更为靠前的位置。文章的排序涉及到两个参数,它们分别是order与orderby,前者决定文章的升降序,所以相对简单;后者决定文章的排列依据,可选值更为丰富一些。
order参数
首先是order参数,其数据类型为:(string|array),用于指定 “orderby” 参数的升序或降序,默认值为DESC,即降序,如果是数组的话,可用于多个order/orderby集:
- ASC:从最低到最高值的升序(1、2、3;a、b、c);
- DESC:从最高值到最低值的降序(3、2、1;c、b、a)。
比如在主题functions.php文件末尾加入这样一段,刷新主页后会发现,初次发表的文章发表在了页首,博主的第一篇文章是默认的《hello world!》,所以特别醒目;
add_filter( 'posts_orderby', 'wpdit_custom_orderby' );
function wpdit_custom_orderby( $orderby ) {
$orderby = "ID ASC";
return $orderby;
}
上面这段程序将全局的循环顺序都变更为了按照id值升序排列,如果想要修改为降序排列,可以修改成下面这样;
add_filter( 'posts_orderby', 'wpdit_custom_orderby' );
function wpdit_custom_orderby( $orderby ) {
$orderby = "ID DESC";
return $orderby;
}
全局修改文章的输出顺序简单但是比较呆板,如果主题中包含类似随机文章这样的模块,你可能会尴尬的发现,随机的文章顺序变得跟主循环一摸一样了。所以修改循环,还是尽量仅修改单一模块,循环完成后重置一下参数:
$args = array(
'orderby' => 'ID',
'order' => 'ASC',
);
orderby的可选值
orderby(string|array)按参数对检索到的文章进行排序,默认为"日期(post_date)",可以传递一个或多个选项。
- none - 不指定顺序;
- ID - 按文章ID排序,注意大小写;
- author - 按作者排序;
- title - 按标题排序;
- name - 按文章名称排序(post slug);
- type – 按文章类型排序(自 4.0 版起可用);
- date – 按日期排序;
- modified – 按最后修改日期排序;
- parent - 按文章/页面父ID排序;
- rand - 随机顺序;
- comment_count - 按评论数量排序(自 2.9 版起可用);
- relevance - 按以下顺序按搜索词排序:首先,是否匹配整个句子。其次,如果所有搜索词都在标题内。第三,如果任何搜索词出现在标题中。第四,如果完整的句子出现在内容中;
- menu_order - 按页面顺序排序。最常用于页面(编辑页面属性框中的顺序字段)和附件(插入/上传媒体库对话框中的整数字段),但可用于具有不同 ' menu_order' 值的任何文章类型(它们都默认为0 );
- meta_value – 请注意,meta_key=keyname查询中还必须存在一个 ' '。另请注意,排序将按字母顺序排列,这对于字符串(即单词)很好,但对于数字(例如 1、3、34、4、56、6 等,而不是 1、3、4、6、 34、56,正如您自然所期望的那样)。使用meta_value_num 代替数值。meta_type如果要将元值转换为特定类型,也可以指定 ' '。可能的值是"NUMERIC","BINARY","CHAR","DATE","DATETIME","DECIMAL","SIGNED","TIME","UNSIGNED",与""中的相同$meta_query。使"meta_type"时,您也可以相应地使用"meta_value_*"。例如,当使用 DATETIME 作为 'meta_type' 时,您可以使用 'meta_value_datetime' 来定义订单结构;
- meta_value_num - 按数字元值排序(自 2.8 版起可用)。另请注意,meta_key=keyname查询中还必须存在""。该值允许进行数字排序,如上面" meta_value"中所述;
- post__in - 保留 post__in 数组中给出的文章 ID 顺序(从 3.5 版开始可用)。注意 – order 参数的值不会更改生成的排序顺序;
- post_name__in - 保留在 'post_name__in' 数组中给出的 post slug 顺序(从版本 4.6 开始可用)。注意 – order 参数的值不会更改生成的排序顺序;
- post_parent__in - 保留在 'post_parent__in' 数组中给出的后父顺序(从版本 4.6 开始可用)。注意 – order 参数的值不会更改生成的排序顺序。
尝试改造主循环
如果想让主循环按照id排序,可以在主循环前加上这么一句:
<?php query_posts('orderby=ID');
while ( have_posts() ) : the_post(); ?>
如果偏好主循环以升序排列的情况,则需要加上order参数:
<?php query_posts('orderby=ID&order=ASC');
while ( have_posts() ) : the_post(); ?>
循环结束记得重置一下循环:
<?php endwhile;
wp_reset_query(); ?>