2015-02-06 122 views
0

我目前正在使用Woocommerce爲WordPress網站構建我自己的自定義高級搜索功能。您應該可以使用過濾器來搜索:WooCommerce使用WP_Query在價格範圍內搜索產品

  • 類別
  • 最大/最小价格

我目前的進展是附在下面。這使您能夠在URL參數中指定分類段落。返回的將是匹配的帖子:

/** 
* Default arguments 
* @var array 
*/ 

    $query = array(
     'post_status' => 'publish', 
     'post_type' => 'product', 
     'posts_per_page' => 10, 
    ); 

/** 
* Category search 
*/ 

    if(isset($_GET['categories']) && $_GET['categories']) { 
     /** 
     * Comma seperated --- explode 
     * @var [type] 
     */ 

      $categories = explode(',', $_GET['categories']); 

     /** 
     * Add "or" parameter 
     */ 

      $query['tax_query']['relation'] = 'OR'; 

     /** 
     * Add terms 
     */ 

      foreach($categories as $category) { 
       $query['tax_query'][] = array(
         'taxonomy' => 'product_cat', 
         'field' => 'slug', 
         'terms' => $category, 
        ); 
      } 
    } 
/** 
* Fetch 
*/ 

    $wp_query = new WP_Query($query); 

現在,而當你要搜索的類別,似乎它獲得的方式更加複雜,當你需要通過價格來搜索這個偉大工程。

在原始SQL,像下面將工作:

SELECT DISTINCT ID, post_parent, post_type FROM $wpdb->posts 
INNER JOIN $wpdb->postmeta ON ID = post_id 
WHERE post_type IN ('product', 'product_variation') AND post_status = 'publish' AND meta_key = '_price' AND meta_value BETWEEN 200 AND 1000 

我不知道我怎麼能實現這個使用WP_Query。

回答

3

您可以在使用WP_Query(或get_posts,我發現在使用中侵入性較低)時組合多個meta_queries。

http://codex.wordpress.org/Class_Reference/WP_Meta_Query

http://codex.wordpress.org/Class_Reference/WP_Query

你可以做這樣的

$myposts = get_posts(
    array(
     'post_type' => array('product', 'product_variation'), 
     'meta_query' => array(
      array(
       'key' => '_price', 
       'value' => '200', 
       'compare' => '>=' 
      ), 
      array(
       'key' => '_price', 
       'value' => '2000', 
       'compare' => '<=' 
      ) 
     ) 
    ) 
); 
2

一些解決方案,通過@Niels麪包車Renselaar激發它們組合起來,但更乾淨:

$query = array(
    'post_status' => 'publish', 
    'post_type' => 'product', 
    'posts_per_page' => 10, 
    'meta_query' => array(
     array(
      'key' => '_price', 
      'value' => array(50, 100), 
      'compare' => 'BETWEEN', 
      'type' => 'NUMERIC' 
     ) 
    ) 
); 

$wpquery = WP_Query($query); // return 10 products within the price range 50 - 100 
+0

啊,offcourse .. :) – 2015-02-06 14:47:03

2

如果你在woocom裏面工作當你可以使用廁所鉤梅爾切循環

add_action('woocommerce_product_query', 'example_product_query_price'); 

function example_product_query_price ($q) { 
    $meta_query = $q->get('meta_query'); 

    $meta_query[] = array(
     'key'  => '_regular_price', 
     'value' => array(
      300000 , 
      900000 
     ), 
     'compare' => 'BETWEEN', 
     'type'=> 'NUMERIC' 
    ); 

    $q->set('meta_query', $meta_query); 
} 
+0

謝謝你。這個對我有用。 – 2016-08-19 10:11:29