Wordpress - 在主页上显示某些类别

时间:2012-09-19 21:04:46

标签: wordpress wordpress-theming

我一直试图改变我当前的代码,但这对我来说没有任何意义(它没有做我告诉它的事情)。我想要做的只是在我的主页上显示类别为13的帖子,我希望能够在帖子中添加多个类别。

  • 帖子1(类别13和1)=显示在主页
  • 帖子2(类别13和4和5)=显示在主页上
  • 第3期(第6类和第1类)=在主页上不可见
  • 帖子4(类别2)=在主页上不可见

这是我当前的代码,仅在我的主页上显示类别13,如果在帖子中添加了另一个类别则根本不会显示。

<?php get_header(); ?>

<div id="primary">
<div id="content" role="main">

<?php
    if (is_home()) {
        query_posts("cat=-6,-4,-1,-11");
    }
?>

<?php if ( have_posts() ) : ?>
<?php twentyeleven_content_nav( 'nav-above' ); ?>
    <?php /* Start the Loop */ ?>
    <?php while ( have_posts() ) : the_post(); ?>
        <?php get_template_part( 'content', get_post_format() ); ?>
    <?php endwhile; ?>

<?php
    $paged = (get_query_var('paged')) ? get_query_var('paged') : 1;
    $args = array(
    'cat' => 13,
    'posts_per_page' => 5,
    'paged' => $paged);
    query_posts($args);
?>

<?php twentyeleven_content_nav( 'nav-below' ); ?>

<?php else : ?>
    <article id="post-0" class="post no-results not-found">
    <header class="entry-header">
    <h1 class="entry-title"><?php _e( 'Geen berichten beschikbaar', 'twentyeleven' ); ?></h1>
    </header><!-- .entry-header -->

    <div class="entry-content">
    <p><?php _e( 'Helaas, er zijn nog geen gearchiveerde berichten in deze categorie. ', 'twentyeleven' ); ?></p>
    <?php get_search_form(); ?>
    </div><!-- .entry-content -->
    </article><!-- #post-0 -->
<?php endif; ?>

3 个答案:

答案 0 :(得分:4)

你对这段代码的看法太难了。您不需要排除任何内容,只需要包含cat 13,其中包含cat 13中的所有内容; 甚至,如果它也在其他类别中。只需像这样运行常规WP_Query()

<?php get_header(); ?>

<div id="primary">
<div id="content" role="main">

<?php
    if (is_home()) {
        // The Query
        $the_query = new WP_Query("cat=13, paged=".get_query_var('paged'));
    }
?>

<?php if ( have_posts() ) : ?>
<?php twentyeleven_content_nav( 'nav-above' ); ?>
    <?php /* Start the Loop */ ?>
    <?php while ( $the_query->have_posts() ) : $the_query->the_post(); ?>
        <?php get_template_part( 'content', get_post_format() ); ?>
    <?php endwhile; ?>
<?php twentyeleven_content_nav( 'nav-below' ); ?>

<?php else : ?>
    <article id="post-0" class="post no-results not-found">
    <header class="entry-header">
    <h1 class="entry-title"><?php _e( 'Geen berichten beschikbaar', 'twentyeleven' ); ?></h1>
    </header><!-- .entry-header -->

    <div class="entry-content">
    <p><?php _e( 'Helaas, er zijn nog geen gearchiveerde berichten in deze categorie. ', 'twentyeleven' ); ?></p>
    <?php get_search_form(); ?>
    </div><!-- .entry-content -->
    </article><!-- #post-0 -->
<?php endif; ?>

(必须添加几个字符或我无法编辑,抱歉:P)

答案 1 :(得分:1)

试试这个......

<?php
  $temp = $wp_query; 
  $wp_query = null; 
  $wp_query = new WP_Query(); 
  $wp_query->query('showposts=6&cat=13'.'&paged='.$paged);
?>
<?php while ($wp_query->have_posts()) : $wp_query->the_post(); ?>

    Your stuff goes here...

<?php endwhile; ?>
<?php 
  $wp_query = null; 
  $wp_query = $temp;  // Reset
?>

答案 2 :(得分:1)

试试此代码

<?php
global $post;
if (is_home()) {
    $args = array( 'numberposts' => 5, 'category' => 13 );
    $myposts = get_posts( $args );
    foreach( $myposts as $post ) :  setup_postdata($post); ?>
        <h2><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a></h2>
            <div class="entry-content">
                <?php the_content( 'Continue reading <span class="meta-nav">&raquo;</span>); ?>
            </div>
    <?php endforeach;
}
?>

这将显示标题和内容。如果您需要其他信息,如日期,作者,类别,标签等,您可能必须使用其他模板标签。此外,如果您想要以不同的方式设置样式,那么您必须使用适当的CSS。