遍历 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”更改为您希望每行分组的数量。
注:此为自答
在 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”更改为您希望每行分组的数量。