繁体   English   中英

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

[英]Wordpress Custom Post Type Query Issue

head了将近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();

?>

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

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

删除代码以构建数组,然后尝试使用此代码代替当前的输出代码:

<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。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM