遍历 WordPress posts,并将每个 X post 包装在 DIV 中

Loop through WordPress posts, and wrap each X post in a DIV

注:此为自答

在 WordPress 中构建不对称网格布局时,您通常希望将每个 X post 包裹在 div 中,如下所示:

div
    post
    post
/div
div
    post
    post
/div
div
    post
    post
/div

我想避免使用模运算符,因为它很快就会造成混淆。

大多数人使用模运算符来执行此操作,但如果没有找到 post,甚至在最后一个 post 上发生除法,这样做会很尴尬。我对@The Shift Exchange 的 answer provided here 进行了扩展,以一种更简洁的方式进行。

<?php
    // Get posts (tweak args as needed)
    $args = array(
        'post_type'        => 'page',
        'orderby'          => 'menu_order',
        'posts_per_page'   => -1,
        'post_parent'      => $post->ID,
        'order'            => 'ASC'
    );
    $posts = get_posts( $args );
?>

<?php foreach (array_chunk($posts, 2, true) as $posts) :  ?>

    <div class="row">

        <?php foreach( $posts as $post ) : setup_postdata($post); ?>

            <a id="post-<?php the_ID(); ?>" <?php post_class(); ?> href="<?php the_permalink(); ?>">
                <?php the_post_thumbnail(); ?>
            </a>

        <?php endforeach; ?>

    </div>

<?php endforeach; ?>

您可以将第一个 foreach 循环中的“2”更改为您希望每行分组的数量。