gpt4 book ai didi

php - wp_reset_query() wordpress - 无法重置最后一个查询

转载 作者:可可西里 更新时间:2023-10-31 22:56:31 24 4
gpt4 key购买 nike

我试图在一个页面上运行两个查询。第一个显示自定义用户搜索的结果第二个只是应该显示最近的记录,其中有一些硬编码到查询中的自定义参数。

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

我试过放置这些 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', '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;
}

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

remove_filter( 'posts_where', 'posts_where_title');

关于php - wp_reset_query() wordpress - 无法重置最后一个查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14104204/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com