每三分之一后重新运行循环? (WordPress的)

我的模板(wordpress)有问题。 我想创建一个包含3列的投资组合页面,并且可以在我的投资组合页面中显示帖子(无需跳转新页面)。 我需要在每篇文章后重复这三篇文章。 我将把“隐藏”类分配给我的重复帖子,当点击列时,类应设置为“块”。 我有一个代码:

<?php get_header(); ?>
<section> <div class="container container-bazar container-gallery"><?php 
$array = array();
    $count = 0;
    $i = 0;
$args = array(
    'posts_per_page' =>  -1,
    'post_type' => 'gallery',
);
$gallery = new WP_Query( $args );
if($gallery->have_posts()) :
while($gallery->have_posts()) :
        $gallery->the_post(); ?>
<div class="col-1 boxes<?php if( $count%3 == 0 ) { echo '-1'; }; $count++; ?>">
    <div class="post" id="post-<?php the_ID(); ?>">
        <figure class="indent-bot">
            <a href="<?php the_permalink(); ?>" rel="nofollow">
                <?php the_post_thumbnail(array(380,220,true)); ?>
            </a>
        </figure>
        <div class="col-1-content">
            <strong class="title-3">
                <a href="<?php the_permalink(); ?>" rel="nofollow">
                    <?php the_title(); ?>
                </a>
            </strong>
            <div class="entry">
                <a href="<?php the_permalink(); ?>" rel="nofollow">
                    <?php the_excerpt(); ?>
                </a>
            </div><!-- .entry -->
        </div><!-- .col-1-content-->
    </div><!-- .post -->
</div> <!-- .boxes -->
<?php endwhile; ?>
<?php while($gallery->have_posts()) :
$gallery->the_post();?>
<?php $imgaddr1 = get_post_meta($post->ID, 'imgaddr1', true);
$imgaddr2 = get_post_meta($post->ID, 'imgaddr2', true);
$imgssilka1 = get_post_meta($post->ID, 'imgssilka1', true);
$imgssilka2 = get_post_meta($post->ID, 'imgssilka2', true);
$namecolor1 = get_post_meta($post->ID, 'namecolor1', true);
$namecolor2 = get_post_meta($post->ID, 'namecolor2', true);
$numbercolor1 = get_post_meta($post->ID, 'numbercolor1', true);
$numbercolor2 = get_post_meta($post->ID, 'numbercolor2', true); ?>
</div>
        <div class="full clearfix">
            <div class="inner">
                <figure class="indent-bot1">
                    <a href="<?php the_permalink(); ?>" rel="nofollow">
                        <?php the_post_thumbnail(array(960,690)); ?>
                    </a>
                </figure>
                <div class="row">
                    <div class="col-md-5">
                        <div class="inf-1">
                            <h4>Информация</h4>
                        </div>
                        <div class="inf-2">
                            <h5><?php the_title(); ?></h5>
                            <div class="desc">
                                <?php the_excerpt(); ?>
                            </div>
                        </div>
                        <div class="clearfix"></div>
                    </div>
                    <div class="col-md-7 border-left">
                        <div class="inf-1">
                            <h4>Приложенные Цвета</h4>
                        </div>
                        <div class="inf-2">
                            <ul>
                                <li class="first-child">
                                    <a href="<?php echo $imgssilka1; ?>" class="img-block">
                                        <img src="<?php echo $imgaddr1; ?>">
                                    </a>
                                    <div class="txt">
                                        <strong><?php echo $namecolor1; ?></strong>
                                        <span><?php echo $numbercolor1; ?></span>
                                    </div>
                                </li>
                                <li class="last-child">
                                    <a href="<?php echo $imgssilka2; ?>" class="img-block">
                                        <img src="<?php echo $imgaddr2; ?>">
                                    </a>
                                    <div class="txt">
                                        <strong><?php echo $namecolor2; ?></strong>
                                        <span><?php echo $numbercolor2; ?></span>
                                    </div>
                                </li>
                            </ul>
                        </div>
                        <div class="clearfix"></div>
                    </div>
                </div>
            </div><!-- .inner -->
        </div>
<div class="container container-bazar container-gallery">
<?php endwhile; 
else: 
endif; ?>
</div><!-- .container -->
</section>
<?php get_footer(); ?>

但是此代码依次显示帖子。


这是我想到的相当不寻常的设置。 有没有重新运行循环的方法

这是如何

  • 你只需要运行一次循环。 代替默认循环,我们将从查询中提取我们的posts数组,并通过foreach循环运行我们的帖子。 这是我们开始工作的地方

  • 我们需要分割我们的内容,这样我们可以得到两个包含发布数据的数据块,并且需要将这些数据保存到我们稍后会使用的数组中。 为了实现这一点,建立两个连接的数据串(一个字符串与第一个数据块,第二个与第二个数据块),它们将被保存在两个独立的变量中。

  • 一旦完成,我们需要添加我们的div来形成包含三个帖子的帖子,每个帖子都有一个独特的类。 这适用于两组字符串

  • 现在我们需要计算新的数组键值,这样我们就可以构建一个新的数据排序数组,这样我们就可以得到一系列的帖子数据,其中包含三个来自字符串1的帖子,然后是一个帖子数据块,两个等

  • 最后,因为我们的帖子数组仍然是混合的并且失序,所以我们将对数组进行排序,使得键是数字的,然后我们可以使用最后一个foreach循环来输出我们的发布数据

  • 这是代码

    在发布代码之前,只需要一两个注释

  • 您需要修改类等来满足您的需求

  • 代码没有完全测试,但div块和排序按预期工作

  • 我已经评论了代码,以便更容易遵循

  • 最后,代码

    $args = array(
        'posts_per_page' =>  -1,
        'post_type' => 'gallery',
    );
    $gallery = new WP_Query( $args );
    
    // Check if we have posts before we continue
    if( $gallery->have_posts() ) {
    
        // Use the array of posts and a foreach loop to build out super array
        foreach ( $gallery->posts as $key=>$post ) {
            // Setup postdata so we can make use of template tags
            setup_postdata( $post );
    
            // Setup/define our first variable which will hold our first set of post data
            $output = '';
    
            // Open a new div on the first post and every 3rd one there after to hold three posts
            if ( $key%3 == 0 ) {
                // We will call this class "first-x" where x represents the block count
                $output .= '<div class="first-' . floor( $key / 3 ) . '">';
            }
    
            // Concatenate your first loop into a string to our first variable $output
            $output .= '<div class="post" id="post-' . $post->ID . '">
                    <figure class="indent-bot">
                        <a href="' . get_the_permalink() . '" rel="nofollow">
                            ' . get_the_post_thumbnail( $post->ID, array( 380,220,true ) ) . '
                        </a>
                    </figure>
                    <div class="col-1-content">
                        <strong class="title-3">
                            <a href="' . get_the_permalink() . '" rel="nofollow">
                                ' . get_the_title() . '
                            </a>
                        </strong>
                        <div class="entry">
                            <a href="' . get_the_permalink() . '" rel="nofollow">
                                ' . get_the_excerpt() . '
                            </a>
                        </div><!-- .entry -->
                    </div><!-- .col-1-content-->
                </div><!-- .post -->
            </div> <!-- .boxes -->';
    
            // Add our closing div after every third post or the last post if there is less than three
            if ( $key%3 == 2 || !array_key_exists( ( $key + 1 ), $gallery->posts ) ) {
                $output .= '</div>';
            }
    
            // Create our new array of post data split in two and use with new array keys
            $new_posts_array[floor( $key / 3 ) * 3 + $key] = $output;
    
            // Setup/define our second variable which will hold the second set of post data from our posts
            // This is the set that you would like to hide
            $output_1 = '';
    
            // Open a new div on the first post and every 3rd one there after to hold three posts
            if ( ( $key%3 ) == 0 ) {
                // This block of posts will use class "second-x" where x represents the block count
                $output_1 .= '<div class="second-' . floor( $key / 3 ) . '">';
            }
    
            $imgaddr1     = get_post_meta( $post->ID, 'imgaddr1',     true );
            $imgaddr2     = get_post_meta( $post->ID, 'imgaddr2',     true );
            $imgssilka1   = get_post_meta( $post->ID, 'imgssilka1',   true );
            $imgssilka2   = get_post_meta( $post->ID, 'imgssilka2',   true );
            $namecolor1   = get_post_meta( $post->ID, 'namecolor1',   true );
            $namecolor2   = get_post_meta( $post->ID, 'namecolor2',   true );
            $numbercolor1 = get_post_meta( $post->ID, 'numbercolor1', true );
            $numbercolor2 = get_post_meta( $post->ID, 'numbercolor2', true ); 
    
            // Concatenate your second set of post data into a string to our second variable $output_1
            $output_1 .= '<div class="full clearfix">
                <div class="inner">
                    <figure class="indent-bot1">
                        <a href="' . get_the_permalink() . '" rel="nofollow">
                            ' . get_the_post_thumbnail(  $post->ID, array( 960, 690 ) ) . '
                        </a>
                    </figure>
                    <div class="row">
                        <div class="col-md-5">
                            <div class="inf-1">
                                <h4>Информация</h4>
                            </div>
                            <div class="inf-2">
                                <h5>' . get_the_title() . '</h5>
                                <div class="desc">
                                    ' . get_the_excerpt() . '
                                </div>
                            </div>
                            <div class="clearfix"></div>
                        </div>
                        <div class="col-md-7 border-left">
                            <div class="inf-1">
                                <h4>Приложенные Цвета</h4>
                            </div>
                            <div class="inf-2">
                                <ul>
                                    <li class="first-child">
                                        <a href="' . $imgssilka1 . '" class="img-block">
                                            <img src="' . $imgaddr1 . '">
                                        </a>
                                        <div class="txt">
                                            <strong>' . $namecolor1 . '</strong>
                                            <span>' . $numbercolor1 . '</span>
                                        </div>
                                    </li>
                                    <li class="last-child">
                                        <a href="' . $imgssilka2 . '" class="img-block">
                                            <img src="' . $imgaddr2 . '">
                                        </a>
                                        <div class="txt">
                                            <strong>' . $namecolor2 . '</strong>
                                            <span>' . $numbercolor2 . '</span>
                                        </div>
                                    </li>
                                </ul>
                            </div>
                            <div class="clearfix"></div>
                        </div>
                    </div>
                </div><!-- .inner -->
            </div>';
    
            // Add our closing div after every third post or the last post if there is less than three
            if ( $key%3 == 2 || !array_key_exists( ( $key + 1 ), $gallery->posts ) ) {
                $output_1 .= '</div>';
            }
    
            // Create our new array of post data split in two and use with new array keys
            $new_posts_array[( floor( $key / 3 ) + 1 ) * 3 + $key] = $output_1;         
    
    
        }
        wp_reset_postdata();
    
        // Sort our new array so that the keys are numerical again
        ksort( $new_posts_array );
    
        // Run a foreach loop to output our posts as we need. No need to modify anything here
        foreach ( $new_posts_array as $v )
            echo $v;
    }
    

    $i = 1;
    //added before to ensure it gets opened
    echo '<div>';
    if ( $wp_query->have_posts() ) : while ( $wp_query->have_posts() ) : $wp_query->the_post();
         // post stuff...
    
         // if multiple of 3 close div and open a new div
         if($i % 3 == 0) {echo '</div><div>';}
    
    $i++; endwhile; endif;
    //make sure open div is closed
    echo '</div>';
    

    众所周知,WordPress是一款开源工具,所有插件都可用于管理这种格式。

    我建议使用插件来管理您的需求。 我已经使用列插件格式化输出。

    链接地址: http://www.djcxy.com/p/26831.html

    上一篇: Rerun loop after every third post? (Wordpress)

    下一篇: MVC5 & SSRS ReportViewer