.= 'tag.htm'; break; case 'flag': $pre .= $default_pre .= 'flag.htm'; break; case 'my': $pre .= $default_pre .= 'my.htm'; break; case 'my_password': $pre .= $default_pre .= 'my_password.htm'; break; case 'my_bind': $pre .= $default_pre .= 'my_bind.htm'; break; case 'my_avatar': $pre .= $default_pre .= 'my_avatar.htm'; break; case 'home_article': $pre .= $default_pre .= 'home_article.htm'; break; case 'home_comment': $pre .= $default_pre .= 'home_comment.htm'; break; case 'user': $pre .= $default_pre .= 'user.htm'; break; case 'user_login': $pre .= $default_pre .= 'user_login.htm'; break; case 'user_create': $pre .= $default_pre .= 'user_create.htm'; break; case 'user_resetpw': $pre .= $default_pre .= 'user_resetpw.htm'; break; case 'user_resetpw_complete': $pre .= $default_pre .= 'user_resetpw_complete.htm'; break; case 'user_comment': $pre .= $default_pre .= 'user_comment.htm'; break; case 'single_page': $pre .= $default_pre .= 'single_page.htm'; break; case 'search': $pre .= $default_pre .= 'search.htm'; break; case 'operate_sticky': $pre .= $default_pre .= 'operate_sticky.htm'; break; case 'operate_close': $pre .= $default_pre .= 'operate_close.htm'; break; case 'operate_delete': $pre .= $default_pre .= 'operate_delete.htm'; break; case 'operate_move': $pre .= $default_pre .= 'operate_move.htm'; break; case '404': $pre .= $default_pre .= '404.htm'; break; case 'read_404': $pre .= $default_pre .= 'read_404.htm'; break; case 'list_404': $pre .= $default_pre .= 'list_404.htm'; break; default: $pre .= $default_pre .= theme_mode_pre(); break; } if ($config['theme']) { $conffile = APP_PATH . 'view/template/' . $config['theme'] . '/conf.json'; $json = is_file($conffile) ? xn_json_decode(file_get_contents($conffile)) : array(); } !empty($json['installed']) and $path_file = APP_PATH . 'view/template/' . $config['theme'] . '/htm/' . ($id ? $id . '_' : '') . $pre; (empty($path_file) || !is_file($path_file)) and $path_file = APP_PATH . 'view/template/' . $config['theme'] . '/htm/' . $pre; if (!empty($config['theme_child']) && is_array($config['theme_child'])) { foreach ($config['theme_child'] as $theme) { if (empty($theme) || is_array($theme)) continue; $path_file = APP_PATH . 'view/template/' . $theme . '/htm/' . ($id ? $id . '_' : '') . $pre; !is_file($path_file) and $path_file = APP_PATH . 'view/template/' . $theme . '/htm/' . $pre; } } !is_file($path_file) and $path_file = APP_PATH . ($dir ? 'plugin/' . $dir . '/view/htm/' : 'view/htm/') . $default_pre; return $path_file; } function theme_mode_pre($type = 0) { global $config; $mode = $config['setting']['website_mode']; $pre = ''; if (1 == $mode) { $pre .= 2 == $type ? 'portal_category.htm' : 'portal.htm'; } elseif (2 == $mode) { $pre .= 2 == $type ? 'flat_category.htm' : 'flat.htm'; } else { $pre .= 2 == $type ? 'index_category.htm' : 'index.htm'; } return $pre; } ?>functions - Ordering posts by publish date not working?
最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

functions - Ordering posts by publish date not working?

programmeradmin0浏览0评论

My site has a "Portfolio" page, which pulls in posts in category 3. Here is my code which selects the posts:

<?php
$args = array('cat' => 3,
              'post_type' =>  'post',
              'orderby' => 'date',
              'order' => 'DESC'); 
$postslist = get_posts( $args );    
foreach ($postslist as $post) :  setup_postdata($post); 
?>  
<div class="portfolio-item">
    <?php the_post_thumbnail() ?>
    <a href="<?php the_permalink(); ?>"><?php the_title(); ?></a>
</div>
<?php endforeach; ?>

But the posts appear in a random order each time the page is refreshed, even though I have 'orderby' and 'order' in the arguments. There seems to be a strange interaction with a short section of code in functions.php which looks like this;

    <?php
add_action('pre_get_posts','alter_query');
function alter_query($query){
    if ($query->is_main_query() &&  is_home())
        $query->set('cat', '2');
        $query->set('orderby', 'rand');
}
?>

This code shows a random post from all posts of category 2 on the homepage. Whilst this line is included;

$query->set('cat', '2');

The orderby => date and order => DESC stop working on the portfolio page, but I need that line to select only category 2 posts for the homepage. If anyone could point me in the direction of why this might be happening I'd be very grateful. Thanks

My site has a "Portfolio" page, which pulls in posts in category 3. Here is my code which selects the posts:

<?php
$args = array('cat' => 3,
              'post_type' =>  'post',
              'orderby' => 'date',
              'order' => 'DESC'); 
$postslist = get_posts( $args );    
foreach ($postslist as $post) :  setup_postdata($post); 
?>  
<div class="portfolio-item">
    <?php the_post_thumbnail() ?>
    <a href="<?php the_permalink(); ?>"><?php the_title(); ?></a>
</div>
<?php endforeach; ?>

But the posts appear in a random order each time the page is refreshed, even though I have 'orderby' and 'order' in the arguments. There seems to be a strange interaction with a short section of code in functions.php which looks like this;

    <?php
add_action('pre_get_posts','alter_query');
function alter_query($query){
    if ($query->is_main_query() &&  is_home())
        $query->set('cat', '2');
        $query->set('orderby', 'rand');
}
?>

This code shows a random post from all posts of category 2 on the homepage. Whilst this line is included;

$query->set('cat', '2');

The orderby => date and order => DESC stop working on the portfolio page, but I need that line to select only category 2 posts for the homepage. If anyone could point me in the direction of why this might be happening I'd be very grateful. Thanks

Share Improve this question asked Nov 24, 2020 at 17:01 tomtomthompsontomtomthompson 132 bronze badges
Add a comment  | 

1 Answer 1

Reset to default 0

If the given code is correct it might be the missing brackets on your pre_get_posts conditional. Let's format it with proper indentation and spacing:

function alter_query( $query ) {
    
    if( $query->is_main_query() &&  is_home() )
        $query->set( 'cat', '2' );
        
    $query->set( 'orderby', 'rand' );
    
}
add_action( 'pre_get_posts','alter_query' );

Because there's no brackets for your conditional statement, it will run the first line inside the conditional and all other lines outside. It's shorthand. To fix this we just need to add brackets:

function alter_query( $query ) {
    
    if( $query->is_main_query() && is_home() ) {
    
        $query->set( 'cat', '2' );
        $query->set( 'orderby', 'rand' );
        
    }
    
}
add_action( 'pre_get_posts','alter_query' );

By encapsulating the additional functionality in brackets we ensure that all statements are run only if that condition is met.

发布评论

评论列表(0)

  1. 暂无评论