使用 WordPress,在我的主页上,我希望能够查询在整个分页中保持一致的随机帖子,而粘性仍然首先显示。我已经尽可能地创建了一个一致的流程,但我错过了像其他帖子一样随机出现的便签。
function custom_query($query) {
global $custom_query;
if ( $custom_query && strpos($query, 'ORDER BY RAND()') !== false ) {
$query = str_replace( 'ORDER BY RAND()', $custom_query, $query );
}
return $query;
}
add_filter( 'query', 'custom_query' );
$paged = ( get_query_var('paged') ) ? get_query_var('paged') : 1;
$seed = $_SESSION['seed'];
if ( empty($seed) ) {
$seed = rand();
$_SESSION['seed'] = $seed;
}
global $custom_query;
$custom_query = " ORDER BY rand($seed) ";
$args = array(
'caller_get_posts' => 1,
'orderby' => 'rand',
'paged' => $paged,
);
query_posts($args);
$custom_query = '';
编辑:根据您的建议,我设法使用以下代码解决了它:
$sticky_post_ids = get_option('sticky_posts');
function mam_posts_query($query) {
global $mam_posts_query;
if ($mam_posts_query && strpos( $query, 'ORDER BY RAND()') !== false ) {
$query = str_replace( 'ORDER BY RAND()', $mam_posts_query, $query );
}
return $query;
}
add_filter( 'query','mam_posts_query' );
$paged = (get_query_var('paged')) ? get_query_var('paged') : 1;
$seed = date('Ymdh'); // Sets an hourly random cache
global $mam_posts_query;
$mam_posts_query = " ORDER BY rand($seed) ";
$args = array(
'orderby' => 'rand',
'paged' => $paged,
'post__not_in' => get_option( 'sticky_posts' )
);
$projects = query_posts($args);
$mam_posts_query = '';
if ( $paged === 1 ) {
$stickies = get_posts( array('include' => $sticky_post_ids) );
$projects = array_merge( $stickies, $projects );
}
感谢您的建议!