Wordpress自定义帖子类型查询问题

时间:2015-03-04 15:55:51

标签: php wordpress custom-post-type flexslider advanced-custom-fields

在我的头上刮了将近2个小时之后,我无法解决这个难题。任何可以帮助我的人,我都会非常感谢他。

我在wordpress中创建了一个自定义帖子类型'属性'。我正在尝试以下代码列出页面中的属性。所有这些都显示正常,除了图像。

<?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();

&GT;

1 个答案:

答案 0 :(得分:0)

正如我在评论中提到的,可能值得切换到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。