在我正在建立的wordpress网站上,我有一个自定义帖子(cp_course
),其中包含以下子字段:course_code
,course_duration
,period_a_start
,period_a_end
,period_b_start
,period_b_end
,period_c_start
,period_c_end
,period_d_start
和period_d_end
。
搜索表单具有以下字段:code
,duration
,datefrom
,dateto
。用户可以使用任何这些进行搜索。我只实现了用户使用所有搜索字段的情况:
if(!empty($code) && !empty($duration) && !empty($datefrom) && !empty($dateto))
{
$args = array(
'post_type' => 'cp_course', 'numberposts' =>-1,'orderby' => 'ID', 'order' => 'ASC', 's' => $searchterm,
'meta_query' =>
array(
'relation' => 'AND',
array(
'key' => 'course_code',
'value' => $code,
),
array(
'key' => 'course_duration',
'value' => $duration,
),
array(
'relation' => 'OR',
array(
'relation' => 'AND',
array(
'key' => 'period_a_start',
'compare' => '>=',
'type' => 'numeric',
'value' => date("Ymd", strtotime($datefrom)),
),
array(
'key' => 'period_a_end',
'compare' => '<=',
'type' => 'numeric',
'value' => date("Ymd", strtotime($dateto)),
),
),
array(
'relation' => 'AND',
array(
'key' => 'period_b_start',
'compare' => '>=',
'type' => 'numeric',
'value' => date("Ymd", strtotime($datefrom)),
),
array(
'key' => 'period_b_end',
'compare' => '<=',
'type' => 'numeric',
'value' => date("Ymd", strtotime($dateto)),
),
),//IF I REMOVE the follow lines (period_c_* and period_d_*) then it works
array(
'relation' => 'AND',
array(
'key' => 'period_c_start',
'compare' => '>=',
'type' => 'numeric',
'value' => date("Ymd", strtotime($datefrom)),
),
array(
'key' => 'period_c_end',
'compare' => '<=',
'type' => 'numeric',
'value' => date("Ymd", strtotime($dateto)),
),
),
array(
'relation' => 'AND',
array(
'key' => 'period_d_start',
'compare' => '>=',
'type' => 'numeric',
'value' => date("Ymd", strtotime($datefrom)),
),
array(
'key' => 'period_d_end',
'compare' => '<=',
'type' => 'numeric',
'value' => date("Ymd", strtotime($dateto)),
),
),
),
)
);
$course = get_posts($args);
}
<div class="page_title">
<h3>Courses</h3>
</div>
<?php foreach ($course as $post):setup_postdata($post);?>
<a href="#"><?php the_title();?></a>
<?php endforeach;wp_reset_postdata();?>
但是它似乎没有用。它陷入了一个循环,已经有10分钟了,仍在搜索中。怎么了?
是否有比多个ifs
更简单的逻辑来实现不同的情况?我将使用类似这样的东西,但是它看起来确实很长而且很复杂...:
if(!empty($code) && !empty($duration) && !empty($datefrom) && !empty($dateto))
{....}
else if(empty($code) && !empty($duration) && !empty($datefrom) && !empty($dateto))
{....}
.......
答案 0 :(得分:0)
有趣的问题,我曾经与ACF遇到过同样的挑战。
运行所有这些if会花费很多时间,而且效率不是很高,我说您尝试以下方法:
在运行get_posts并启动$args
并进行相应分配之前,尝试自己构建这些元查询数组,例如:
if($code || $duration || $datefrom || $dateto){
$meta_query = array( array( 'relation' => 'AND' ) );
if ( $code ) {
array_push( $meta_query, array(
array(
'key' => 'course_code',
'value' => $code,
)
) );
}
if($duration){
array_push( $meta_query, array(
array(
'key' => 'course_duration',
'value' => $duration,
)
) );
}
//And so on
}
对于嵌套关系(例如period_a_start)来说,这无疑将更具挑战性,但这是非常简单明了且最简单/最有效的方式。
祝你好运!