Wordpress 按帖子类型订购帖子
Posted
技术标签:
【中文标题】Wordpress 按帖子类型订购帖子【英文标题】:Wordpress order posts by post type 【发布时间】:2013-03-18 12:06:57 【问题描述】:我正在尝试创建一个从 2 种帖子类型中获取帖子的系统,并且我想按帖子类型显示帖子顺序。我试图首先显示来自一种帖子类型的帖子,然后显示另一种帖子类型,但我使用的查询将它们混合在一起。任何人都可以为此提出一个好的解决方案。这是我的代码。
$paged = get_query_var( 'paged' ) ? get_query_var( 'paged' ) : 1;
$args = array(
'post_type' => array('review','directory'),
'orderby' => 'name',
'order' => 'ASC',
'posts_per_page' => '4',
'paged' => $paged ,
'tax_query' => array( array(
'taxonomy' => 'Reviews',
'field' => 'id',
'terms' => $cat_id
), ),
);
query_posts($args);
if (have_posts()) :
while (have_posts()) : the_post();
$product_terms = wp_get_post_terms(get_the_ID(), 'Reviews', array("fields" => "all", "order" => "DESC"));
$postype=get_post_type( get_the_ID() );
if($postype=='review')
?>
<div class="review-post">
<a href="http://<?php the_permalink(); ?>" target="_blank"><h3><?php the_title(); ?></h3></a>
<div class="review-cat-new">
<?php echo get_the_term_list( $post->ID, 'Reviews', 'Category: ', ', ', '' ); ?>
</div>
<?php
if(get_field('see_it'))
$seeit_text= get_field('see_it');
if(get_field('skip_it'))
$skipit_text= get_field('skip_it');
?>
<div class="see-skip">
<p class="see-it"><span>See it:</span>
<?php echo $seeit_text; ?>
</p>
<p class="skip-it"><span>Skip it:</span>
<?php echo $skipit_text; ?>
</p>
</div>
<?php echo custom_field_excerpt(); ?>
</div>
<?php
else
?>
<div class="review-post">
<a href="h<?php the_permalink(); ?>" target="_blank"><h3><?php the_title(); ?></h3></a>
<div class="review-cat-new">
<?php echo get_the_term_list( get_the_ID(), 'Reviews', 'Category: ', ', ', '' ); ?>
</div>
<?php echo the_field('enter_content_direc'); ?>
<?php
if(get_field('enter_textdirec'))
$text= get_field('enter_textdirec');
if(get_field('enter_linkdirec'))
$textlink= get_field('enter_linkdirec');
?>
<div class="see-skip">
<p class="see-it direc"><span><a target="_blank" style="color:#5D6D71; text-transform: lowercase;" href="<?php echo $textlink;?>"><?php echo $textlink;?> </a></span>
</p>
</div>
</div>
<?php
endwhile;
echo '<div class="paging">';
wp_pagenavi();
echo '</div>';
endif;
那么有没有办法让我可以先显示帖子表单评论然后显示目录?
【问题讨论】:
【参考方案1】:我终于找到了解决方案,可以使用过滤器完成。
解决方案如下所示。
add_filter( 'posts_request' , 'modify_request' );
function modify_request( $query)
global $wpdb;
if(strstr($query,"post_type IN ('review', 'directory')"))
$where = str_replace("ORDER BY $wpdb->posts.post_date","ORDER BY $wpdb->posts.post_type",$query);
return $where;
【讨论】:
你把这段代码放在哪里?如果我尝试将其放入 archive-name.php 会出现错误 放到functions.php上 更多信息。如果你只想改变“order by”,wordpress 有posts_orderby_request
过滤器。
嗨@NirmalRam,这里似乎有问题......当不满足if条件时不返回$query,实际上没有产生任何结果。此外,是否应该以这种方式实施 $where 。它不是 $query 对象的属性吗?【参考方案2】:
从 Wordpress 4.0 开始,您只需将选项类型 (post_type) 传递给 WP_Query 对象中的 orderby 参数即可。
orderby (string | array) - 按参数对检索到的帖子进行排序。要按帖子类型订购,只需通过:
'type' - 按帖子类型排序(自 4.0 版起可用)。 (“post_type”也被接受。)【讨论】:
是否可以按特定顺序获取 post_types?例如:数组的顺序。【参考方案3】:如文档 https://developer.wordpress.org/reference/classes/wp_query/#order-orderby-parameters 中所见,您可以通过将数组传递给“orderby”来使用常规 wp 查询:
$wp_query = new WP_Query(
array(
's' => $search,
'orderby'=> array('type'=>'DESC', 'title'=>'ASC'),
'paged'=>$paged
)
);
if ( $wp_query->have_posts() )
while ( $wp_query->have_posts() )
$wp_query->the_post();
// do your loop stufff here
【讨论】:
【参考方案4】:使用自定义帖子类型顺序按帖子类型排序:
add_filter('pre_get_posts', function ($query)
if ($query->is_search && !is_admin()) :
$query->set('post_type', [ 'cpt-1', 'cpt-2', 'post', 'cpt-3']);
endif;
return $query;
);
add_filter('posts_orderby', function ( $order )
if ( ! is_admin() ) :
if ( is_search() && is_main_query() ) :
global $wpdb;
$order = "FIELD( post_type, 'cpt-1', 'cpt-2', 'post' ), $wpdb->posts.post_modified DESC";
endif;
// Disable this filter for future queries!
remove_filter( current_filter(), __FUNCTION__);
endif;
return $order;
);
【讨论】:
【参考方案5】:我想到的第一个解决方案是只获取第一类的帖子。重置查询 (wp_reset_query()
) 并再次为第二类获取它们。你当然需要加倍你的代码,但我没有看到任何其他解决方案 - 它是 WordPress - 你非常有限。
第二种解决方法是直接查询数据库:
$result = mysql_query('SELECT *
FROM `wp_posts`
WHERE post_type = "page"
OR post_type = "post"
ORDER BY post_type ASC , post_date DESC ');
$posts = array();
if($result)
while ($row = mysql_fetch_assoc($result))
$posts[] = $row;
mysql_free_result($result);
echo('<pre>');
var_dump($posts);
echo('</pre>');
die();
请注意,我使用了 post
和 page
类型,因为它们是默认类型,并且存在于我的 WP 安装中。但是你可以使用不同的。您可以随意使用此查询。
【讨论】:
谢谢,但我不想这样,我想要的是按 post_type 对帖子进行排序 那么你可能不得不让你自己的查询 php 函数直接从 db 读取。它适合您吗? 不,这是不对的。我已经想通了,它的工作原理。只需一个过滤器就可以完成这项工作。以上是关于Wordpress 按帖子类型订购帖子的主要内容,如果未能解决你的问题,请参考以下文章
将来自两个不同 wordpress 的帖子合并到一个按日期排序的帖子页面