0

我正在使用 has_scope gem,我想用两个参数创建过滤——它可能是一个参数或两个参数。

我的模型(产品):

scope :brand, proc { |brand| joins(:product_values).where('product_values.value_id' => brand) }
scope :zamena, proc { |zamena| joins(:product_values).where('product_values.value_id' => zamena) }

控制器的索引动作:

 @products = apply_scopes(Product).all

它有效,但只有一个:(

/products?brand=12 - Ok
/products?zamena=24 - Ok
/products?brand=12&zamena=24 - Fail (sorted only by 'zamena', not by both params)

第二。变体(也不起作用) 在我的控制器中:

query = Product.scoped
query = query.brand(params[:brand]) if params[:brand]
query = query.zamena(params[:zamena]) if params[:zamena]
@products = query.all

一个有效,但不能同时有效(0 个结果)。

4

1 回答 1

-1

我的答案。也许不优雅,但效果很好。

  fcount = 0
  fcount += 1 if params[:brand]
  fcount += 1 if params[:zamena]

  prods = []
  if params[:brand]
    Product.all.each do |p|
      prods << p if p.product_values.where(value_id: params[:brand]).count > 0
    end
  end
  if params[:zamena]
    Product.all.each do |p|
      prods << p if p.product_values.where(value_id: params[:zamena]).count > 0
    end
  end

  @products = prods.select{|item| prods.count(item) == fcount}.uniq

不需要范围。您可以使用这种方式使用很多过滤器。

于 2012-12-20T21:49:36.630 回答