我的代码中没有显示错误,我使用Ransak搜索,但我没有得到搜索输出。我想从复选框中选中尺寸选项时获取输出。如果我点击媒体,我想要显示所有中等礼服,像所有 请给我一个解决方案
这是我的复选框
这是我的代码
产品/ index.html.slim
= search_form_for @product_search, url: shop_index_path do |f|
= f.label :size_cont, "Size Available"
- StandardSize.all.each do |s|
= check_box_tag('product_search[standard_sizes_id_eq_any_cont][]', s.id )
= s.name
这是我的ShopController.rb
class ShopController < ApplicationController
def index
@product_search = Product.ransack(params[:q])
@products = @product_search.result(distinct:true).page(params[:page]).per(8)
@product_search.build_sort if @product_search.sorts.empty?
end
model standardsize.rb
class StandardSize < ActiveRecord::Base
belongs_to :product
end
这里是我的模型product.rb
class Product < ActiveRecord::Base
has_and_belongs_to_many :standard_sizes
end
这是我的服务器
Started GET "/shop?utf8=%E2%9C%93&q%5Bname_cont%5D=dress&q%5Bprice_paisas_gteq%5D=&q%5Bprice_paisas_lteq%5D=&product_search%5Bstandard_sizes_id_eq_all%5D%5B%5D=3&commit=Search" for 10.0.2.2 at 2015-07-23 10:12:42 +0000
Cannot render console from 10.0.2.2! Allowed networks: 127.0.0.1, ::1, 127.0.0.0/127.255.255.255
Processing by ShopController#index as HTML
Parameters: {"utf8"=>"✓", "q"=>{"name_cont"=>"dress", "price_paisas_gteq"=>"", "price_paisas_lteq"=>""}, "product_search"=>{"standard_sizes_id_eq_all"=>["3"]}, "commit"=>"Search"}
User Load (0.1ms) SELECT
{用户{1}} {用户{1}} {用户{1}} ID为.* FROM
{用户{1}} ID为WHERE
答案 0 :(得分:4)
除非您已配置Ransack,否则所有搜索参数都应嵌套在@q
下。我也使用_in
代替_eq_any_cont
取得了成功。
替换
= search_form_for @product_search, url: shop_index_path do |f|
= f.label :size_cont, "Size Available"
- StandardSize.all.each do |s|
= check_box_tag('product_search[standard_sizes_id_eq_any_cont][]', s.id )
= s.name
与
= search_form_for @q, url: shop_index_path do |f|
= f.label :size_cont, "Size Available"
- StandardSize.all.each do |s|
= f.check_box :standard_sizes_id_in, {multiple: true}, s.id, nil
= s.name