加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – wp_reset_query()wordpress – 无法重置上一个查询

发布时间:2020-12-13 17:22:40 所属栏目:PHP教程 来源:网络整理
导读:我试图在页面上运行两个查询. 第一个显示自定义用户搜索的结果 第二个只是显示更新的记录,其中一些自定义参数硬编码到查询中. 我遇到的问题是,当运行自定义搜索时,两个查询都会受到影响,并且结果会在两个位置都更新. 我试过放置这些wp_reset_postdata(); ???
我试图在页面上运行两个查询.
第一个显示自定义用户搜索的结果
第二个只是显示更新的记录,其中一些自定义参数硬编码到查询中.

我遇到的问题是,当运行自定义搜索时,两个查询都会受到影响,并且结果会在两个位置都更新.

我试过放置这些wp_reset_postdata();
????wp_reset_query();到处都是,但都没有.

有没有人有任何想法?

这是我的第一个查询

$args = array('post_type' => 'vacancy','post_status' => 'publish' ) );
add_filter( 'posts_where','posts_where_title',10,2 );
function posts_where_title( $where,&$wp_query ) {
global $wpdb;
$where .= ' AND (' . $wpdb->posts . '.post_title LIKE '%' . esc_sql( like_escape( $_POST['post_title'] ) ) . '%'';
$where .= ' OR ' . $wpdb->posts . '.post_content LIKE '%' . esc_sql( like_escape( $_POST['post_title'] ) ) . '%')';
return $where;
}
$the_query = new WP_Query( $args );
if ( $the_query->have_posts() ) : while ( $the_query->have_posts() ) : $the_query->the_post();
//display results ?>
<?php $i++;  endwhile;  endif;  
wp_reset_postdata();
wp_reset_query();?>

这是我的第二个问题……

$args = array( 'post_type' => 'vacancy','posts_per_page' => 10 );
query_posts( "_vacancy_ends>=".date("Y-m-d")."&_vacancy_starts<=".date("Y-m-d")."&order=DESC" );
$loop = new WP_Query( $args );
while ( $loop->have_posts() ) : $loop->the_post();
//display results
endwhile;
wp_reset_postdata();
wp_reset_query();

解决方法

你的问题是这一行:

query_posts( "_vacancy_ends>=".date("Y-m-d")."&_vacancy_starts<=".date("Y-m-d")."&order=DESC" );

query_posts影响主循环,几乎影响该给定页面请求中运行的每个其他循环.在很少的情况下,将它用于WP_Query甚至get_posts被视为良好做法,因为您正在影响Wordpress用于填充有关正在查看的内容的信息的大量全局变量.

就个人而言,我通常不会在WP_Query上使用查询方法,但在这种情况下它可能会有所帮助.尝试将第二个查询更改为以下内容:

$args = array( 'post_type' => 'vacancy','posts_per_page' => 10 );
$loop = new WP_Query( $args );
$loop->query( "_vacancy_ends>=".date("Y-m-d")."&_vacancy_starts<=".date("Y-m-d")."&order=DESC" );
while ( $loop->have_posts() ) : $loop->the_post();
    //display results
endwhile;
wp_reset_postdata();
wp_reset_query();

这会将您的查询本地化为单个WP_Query实例,而不是全局影响所有内容.这是未经测试的,但请告诉我这是否有帮助.

还有一件事:

add_filter( 'posts_where',&$wp_query ) {
    global $wpdb;
    $where .= ' AND (' . $wpdb->posts . '.post_title LIKE '%' . esc_sql( like_escape( $_POST['post_title'] ) ) . '%'';
    $where .= ' OR ' . $wpdb->posts . '.post_content LIKE '%' . esc_sql( like_escape( $_POST['post_title'] ) ) . '%')';
    return $where;
}

请记住,此过滤器将在您调用add_filter后设置的每个查询上运行.您可能需要考虑在其后的更多查询不需要运行过滤器的位置删除过滤器:

remove_filter( 'posts_where','posts_where_title');

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读