0

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

我的 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

?>

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

  • 用户输入有效数据时的实际查询(“查询”而不是“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

有没有人有任何提示可以分享?你能帮我一把真是太酷了!谢谢丹

4

1 回答 1

0

您现在可能已经解决了这个问题,但是您的查询有 ... where 1=1 and 0=1 ... 所以它不会返回任何东西,因为您要求的是一个记录集,包括真假。

于 2012-10-17T20:28:26.820 回答