2

我的应用程序中有两个主要模型,“业务”和“类别”。我目前有一个可以正常工作的搜索 text_field,但我也在尝试实现用户根据包含可用类别的 collection_select 搜索“属于”某个类别的企业的能力。

我有 collection_select 工作,但我似乎无法弄清楚如何让它显示“属于”所选类别的企业。

这是我的业务控制器中的搜索信息:

  def search
    if params[:search].present?
      @businesses = Business.search(params[:search])
    else
      @businesses = Business.all.paginate(page: params[:page], per_page: 6)
    end
  end

我的搜索表格:

<%= form_tag search_businesses_path, method: :get, role: "search", :class => "search" do %>
    <%= label :category, "Search By Business Name" %>
    <%= text_field_tag :search, params[:search], id: "search", :placeholder => 'Search Business' %>
    <%= button_tag(type: 'submit', class: "button") do %>
        <i class="fa fa-arrow-right"></i>
    <% end %>
<% end %>

而我目前的类别收藏选择:

<%= form_for :category do |f| %>
    <%= f.label :category, "Search By Category" %><br>
    <%= f.collection_select :category_id, Category.all.order('name ASC'), :id, :name %>
    <%= button_tag(type: 'submit', class: "button") do %>
        <i class="fa fa-arrow-right"></i>
    <% end %>
<% end %>

我知道我需要告诉集合选择它需要显示业务,但我似乎无法弄清楚如何正确实施它。

更新

我尝试了以下代码,但没有出现任何结果:

我的商业模式

def search_data
    {
      name: name,
      category_id: category_id
    }
end

我的业务控制器

def search
    if params[:search].present?
      @businesses = Business.search "apples", where: { category_id: params[:category_id] }
    else
      @businesses = Business.all.paginate(page: params[:page], per_page: 6)
    end
  end

我的表格

<%= form_tag search_businesses_path, method: :get, role: "search", :class => "search" do %>
    <%= label :category, "Search By Category" %>
    <%= collection_select :search, params[:category_id], Category.all.order('name ASC'), :id, :name %>
    <%= button_tag(type: 'submit', class: "button") do %>
        <i class="fa fa-arrow-right"></i>
    <% end %>
<% end %>
4

1 回答 1

0

这对你有用吗:

Business模型中定义这个方法:

def search_data
  {
    name: name,
    category_id: category_id
  }
end

或者我认为你也可以这样写(不确定):category: category.name

所以这也会索引category,你可以在你的控制器中使用它进行搜索,如下所示:

Business.search "apples", where: { category_id: params[:category_id] }

或者如果category.name作品那么{ category: params[:category] }

根据params您的form.

于 2016-03-20T16:53:34.593 回答