简体   繁体   English

PHP:如果“ if”语句为true,则执行while循环

[英]PHP: Doing while loop if “if” statement is true

I am trying to show only those events, which are in current date or in future. 我试图仅显示那些发生在当前日期或将来的事件。 To show events I have such code: 为了显示事件,我有这样的代码:

<?php 
    $wp_query = new WP_Query();
    global $more;
    // set $more to 0 in order to only get the first part of the post
    $more = 0; 
    $wp_query->query( array( 'post_type' => 'events', 'posts_per_page' => 7, 'paged' => $paged, 'orderby' => 'menu_order', 'order' => 'ASC') );

    while ( ($wp_query->have_posts()) ): $wp_query->the_post();
        get_template_part( 'content', 'event' );
    endwhile;
?>

I tried to add "IF statement" to compare event start date with current date, but it doesn't seem to work. 我尝试添加“ IF语句”以将事件开始日期与当前日期进行比较,但似乎不起作用。 I have tried a lots of versions, but this one I think should work: 我尝试了很多版本,但是我认为应该可以使用:

 $wp_query->query( array( 'post_type' => 'events', 'posts_per_page' => 7, 'paged' => $paged, 'orderby' => 'menu_order', 'order' => 'ASC') );
 $OstartDate = get_post_meta($post->ID, '_event_start', TRUE);
 $today = date('d.m.Y');
 while ( ($wp_query->have_posts()) && ($OstarDate < $today) ): 
      $wp_query->the_post();

From the second one you should try, second one您应该尝试

$OstartDate=get_post_meta($post->ID,'_event_start',TRUE);//check it will return a number
if(time() > $OstartDate)
{
   while ($wp_query->have_posts()):
      $wp_query->the_post();
   .....
}

a7-simple-events may help you. a7-简单事件可能会帮助您。

You can compare the posts with postmeta using meta_query 您可以使用meta_query将帖子与postmeta进行比较

$today = date('d.m.Y');
 $args=array( 'post_type' => 'events', 'posts_per_page' => 7, 'paged' => $paged, 'orderby' => 'menu_order', 'order' => 'ASC', 'meta_query'            => array(
        array(
            'key' => '_event_start',
            'value' => $today,
            'type' => 'date',
            'compare' => '<'
        )
    )) ;
    $wp_query = new WP_Query( $args );

 while ( ($wp_query->have_posts())  ): 
      $wp_query->the_post();
      endwhile;

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

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