wp_query 未在 pre_get_posts 中正确过滤tax_query

问题描述 投票:0回答:1

我遇到以下情况的问题:我正在创建一个自定义表单来搜索我的自定义帖子类型(immobiliare)并附加到此我有 2 个自定义分类法:位置和tipologia。

我的searchform.php是:

<form role="search" method="get" id="searchform" action="<?php echo home_url( '/' ); ?>">
    <input type="hidden" value="proceed" name="s" id="s" />
    <fieldset>
      <legend>Ricerca per:</legend>
      <label class="screen-reader-text" for="query">Testo:</label>
          <input type="text" value="<?php the_search_query(); ?>" name="query" id="query" />
    </fieldset>
    <fieldset>
      <label class="screen-reader-text" for="s">Tipologia:</label>
          <?php wp_dropdown_categories(array(
            'hide_empty' => 0,
            'taxonomy' => 'tipologia',
            'name' => 'tipologia',
            'show_option_all' => 'Nessuna Preferenza'
          )); ?> 
    </fieldset>
    <fieldset>
      <label class="screen-reader-text" for="s">Località:</label>
          <?php wp_dropdown_categories(array(
            'hide_empty' => 0,
            'taxonomy' => 'location',
            'name' => 'location',
            'show_option_all' => 'Nessuna Preferenza'
          )); ?> 
    </fieldset>
    <input type="submit" id="searchsubmit" value="Search" />
</form>

如您所见,我有 3 个字段:1 个是文本字段,另外 2 个是包含我的分类法的下拉菜单。我希望用户能够搜索这些字段。我不得不破解“s”输入类型,因为它不允许我提交空查询,而是添加了“查询”字段。 我的functions.php文件如下:

<?php

  // Start LOGGING
  if(!function_exists('_log')){
    function _log( $message ) {
      if( WP_DEBUG === true ){
        if( is_array( $message ) || is_object( $message ) ){
          error_log( print_r( $message, true ) );
        } else {
          error_log( $message );
        }
      }
    }
  }
  // end LOGGING

  // start SEARCH FORM
  function ij_get_int($var){
    if (isset($var)) {
      $int_var = intval($var);
      if ($int_var > 0)
        return $int_var;
    }
    return false;
  }

  function ij_get_str($var) {
    $str_var = esc_attr($var);
    if (strlen($str_var) > 0)
      return $str_var;
    return false;
  }

  function custom_search_results($query) {
    if ($query->is_search && $query->is_main_query()) {
      $tax_query = array(
        'relation' => 'AND',
      );
      $location = ij_get_int($_GET['location']);
      $tipologia = ij_get_int($_GET['tipologia']);
      if ($location) {
        array_push($tax_query, array(
           'taxonomy' =>   'location',
           'field'    =>   'id',
           'terms'    =>   $location,
           'operator' =>   'IN'
        ));
      }
      if ($tipologia) {
        array_push($tax_query, array(
           'taxonomy' =>   'tipologia',
           'field'    =>   'id',
           'terms'    =>   $tipologia,
           'operator' =>   'IN'
        ));
      }
      $query->set('tax_query', $tax_query);

      $query->set('s', ij_get_str($_GET['query']));
      $query->set('post_type', 'immobiliare');
    }
  }

  add_action('pre_get_posts', 'custom_search_results');
  // end SEARCH FORM

?>

在这里,我连接到自定义表单的响应并添加:

  • 当用户输入有效数据时的实际查询(“query”而不是“s”)。
  • 需要时按分类过滤。

我不知道为什么这不起作用(花了一天!),我可以看到我的查询返回了正确的 's' 参数:

$query->set('s', ij_get_str($_GET['query']));

但不是分类过滤器。

我做错了什么?我想在我的 search.php 文件中使用标准循环,所以在某种程度上我希望我的钩子函数自动插入到循环中。一件奇怪的事情是,如果我使用相同的设置创建一个新的 WP_Query 对象(并且不使用“set”方法),它会返回我想要的内容!我尝试做 $query = new WP_Query...但这也不起作用!!

如果我将查询请求转储到 search.php 的顶部,我会得到以下内容:

SELECT SQL_CALC_FOUND_ROWS  wp_posts.*
FROM wp_posts
WHERE 1=1
    AND 0 = 1
    AND (
         (
          (wp_posts.post_title LIKE '%vil%')
          OR (wp_posts.post_content LIKE '%vil%')
         )
        )
    AND wp_posts.post_type = 'immobiliare'
    AND (wp_posts.post_status = 'publish' OR wp_posts.post_status = 'private')
GROUP BY wp_posts.ID
ORDER BY wp_posts.post_date DESC
LIMIT 0, 10
php wordpress hook custom-post-type custom-taxonomy
1个回答
0
投票

您现在可能已经解决了这个问题,但是您的查询有...其中 1=1 和 0=1 ...所以它不会返回任何内容,因为您要求的是 true 和 false 项的记录集。

最新问题
© www.soinside.com 2019 - 2025. All rights reserved.