Wordpress自定义文章类型查询问题


Wordpress Custom Post Type Query Issue

在挠头将近两个小时后,我无法解开这个谜题。任何能帮助我的人,我都会非常感谢他。

我在wordpress中创建了一个自定义的帖子类型"Properties"。我正在尝试使用以下代码列出页面中的属性。除图像外,所有图像都显示良好。

<?php
$conarg = array (
'post_type' => 'properties',
'order_by' => 'menu_order',
'order' => 'ASC'
);
$condo_query = new WP_Query( $conarg );
    if ( $condo_query->have_posts() ) { ?>
        <?php 
            while ( $condo_query->have_posts() ) {
            $condo_query->the_post();
        ?>
        <?php
            $condo_images_max   = 5;
            $condo_items = array();
            for($i=1; $i <= condo_images_max; $i++) {
                    //check if image exits
                $img_attachment_id  = get_field('gallery-image-'.$i);
                if(!empty($img_attachment_id)) {
                    $condo_items[$i] = array(
                        'image' => wp_get_attachment_image_src($img_attachment_id, 'medium')
                    );
                }
            }
            $condo_items_keys = array_keys($condo_items);
        ?>
    <div class="box col-md-4 col-xs-12">
        <div class="flexslider">
            <ul class="slides">
                <?php
                    for($i=0; $i < count($condo_items) ; $i++) {
                    $image  = $condo_items[$condo_items_keys[$i]]['image'];
                ?>
                <li>
                    <img src="<?php echo $image[0]; ?>" alt="Carousel Image" />
                </li>
                <?php
                }
                ?>
            </ul>
        </div>
        <?php echo '<h2 class="condo-title">' . get_the_title() . '</h2>';
            echo'<ul class="condo-details">';
            if(get_field('area_range')) {
                echo '<li><span>SQ.FT RANGE:</span> ' . get_field('area_range') . '</li>';
                }
            if(get_field('room_view')) {
                echo '<li><span>ROOM VIEW:</span> ' . get_field('room_view') . '</li>';
                }
            if(get_field('price_range')) {
                echo '<li><span>PRICE RANGE:</span> ' . get_field('price_range') . '</li>';
                }
            ?>

            <a class="condo-btn" href="<?php the_permalink(); ?>"><?php _e('VIEW DETAILS'); ?></a>
            <?php   
        echo'</ul></div>';
    }
} 
else {
    echo'Sorry! No Condos are available at the moment!';
}
/* Restore original Post Data */
wp_reset_postdata();

?>

正如我在评论中提到的,可能值得切换到PRO版本并使用中继器字段。

在您的问题中,您不必要地构建了一个数组,然后使用for而不是foreach在数组中循环,从而使这一点过于复杂。

删除构建数组的代码,并尝试使用此方法而不是当前的输出代码:

<ul class="slides">
    <?php // Set maximum number of images to check.
    $condo_images_max = 5;
    for ( $i = 1; $i <= $condo_images_max; $i++ ) {
        // Get image ID.
        $image_id = get_field( 'gallery-image-' . $i );
        // Check if image ID was found.
        if ( $image_id ) {
            // Output medium image in an li tag.
            echo '<li>' . wp_get_attachment_image( $image_id, 'medium' ) . </li>';
        }
    } ?> 
</ul>

如果你需要能够控制图像元素的输出,并以你在问题中显示的方式显示它,你可以使用:

...
if ( $image_id ) {
    // Get image source.
    $image = wp_get_attachment_image_src( $image_id, 'medium' );
    // Check image source was found.
    if ( $image ) {
        echo '<li><img src="' . $image[0] . '" alt="Carousel Image" /></li>';
    }         
}
...

这样做有一个问题需要注意(也是我建议使用中继器的原因之一)。

假设您有6个图像字段,并且一个属性正在使用全部6个。然后管理员决定删除第一个图像,所以现在该属性有5个图像。代码仍然可以工作,因为我们在尝试输出图像之前会检查是否找到图像,但您不会显示所有5个图像,而是只看到其中的4个。图像#1是空的,我们已经告诉它停止照看图像#5。