在一个循环中输出循环内容两次?

时间:2012-04-14 00:22:31

标签: wordpress

我真的很想找点什么来开始这个。

我希望能够在一个循环中输出2个帖子,所以我可以DIV一次包装2个帖子......

我在下面所做的只是纯粹的例子 - 我试图解释我需要它做什么。 如果有人知道某种方式或者我可以在哪里找到教程,那就太棒了!感谢。

THE LOOP

感谢@Rob帮助我做到这一点,但它似乎很奇怪地输出重复...

<?php $latest = new WP_Query(array(

    'category_name'  => 'news',
    'order'          => 'DESC',
    'orderby'        => 'date',
    'posts_per_page' => 6

)); ?>

<?php $i = 0; if ( $latest->have_posts()) : while ($latest->have_posts()) : $latest->the_post(); ?>

    <?php $odd = ++$i % 2; ?>

    <?php if($odd) : ?>
    <div class="dual-post-wrapper">
    <?php endif; ?>

        <div class="post-<?php the_ID(); ?>">

            <?php the_content(); ?>

        </div>

    <?php if(!$odd) : ?>
    </div>
    <?php endif; ?>

<?php endwhile; unset($latest); endif; ?>


输出HTML

这就是输出的HTML看起来像 - 由于某种原因它重复帖子1,2,3和4 ???怪异!

<div class="dual-post-wrapper">

    <div class="post-1">

        Post 1 Content

    </div>

    <div class="post-2">

        Post 2 Content

    </div>

</div>

<div class="dual-post-wrapper">

    <div class="post-3">

        Post 3 Content

    </div>

    <div class="post-4">

        Post 4 Content

    </div>

</div>

<div class="dual-post-wrapper">

    <div class="post-5">

        Post 5 Content

    </div>

    <div class="post-6">

        Post 6 Content

    </div>

</div>

<div class="dual-post-wrapper"> <!-- these are duplicates?? -->

    <div class="post-1">

        Post 1 Content

    </div>

    <div class="post-2">

        Post 2 Content

    </div>

</div>

<div class="dual-post-wrapper"> <!-- these are duplicates?? -->

    <div class="post-3">

        Post 3 Content

    </div>

    <div class="post-4">

        Post 4 Content

    </div>

</div>


再次感谢!!

2 个答案:

答案 0 :(得分:1)

Wordpress内置了用于计算循环和倒回帖子的函数。

计算循环使用次数:

//Create a custom query var:

$displayposts = new WP_Query(); 

//start loop with it
<?php if ($displayposts->have_posts()) :while ($displayposts->have_posts()) : $displayposts->the_post();

//count it
$count_id = $displayposts->current_post + 1; 

//loop stuff <?php endwhile; else:?>

//rewind the post 
rewind_posts();

http://codex.wordpress.org/Function_Reference/rewind_posts

答案 1 :(得分:0)

您可以使用简单的计数器和模数来完成此任务。

<?php $i = 0; if (have_posts()) : while (have_posts()) : the_post(); ?>
<?php $odd = ++$i % 2; ?>

    <?php if($odd) : ?>
        <div class="dual-post-wrapper">
    <?php endif; ?>

            <div class="post-<?php the_ID(); ?>">
                         <?php the_content(); ?>
            </div>

    <?php if(!$odd) : ?>
        </div>
    <?php endif; ?>

<?php endwhile; endif; ?>

如果你总是有一定数量的帖子,这应该有效。您可能应该预先计算帖子数量并关闭div if(!$odd || $last)