Mik*_*ord 5 ruby-on-rails ransack ruby-on-rails-4
我意识到其他人已经问过这个错误,但它与不同的情况有关。
我为 rails 4 添加了 Ransack gem 并捆绑安装:
gem "ransack", github: "activerecord-hackery/ransack", branch: "rails-4"
Run Code Online (Sandbox Code Playgroud)
我还编辑了我的控制器如下(recipes_controller):
def index
if params[:tag]
@all_recipes = Recipe.tagged_with(params[:tag])
else
@all_recipes = Recipe.all
end
if signed_in?
@user_recipes = current_user.recipes.order("created_at DESC").paginate(page: params[:page], :per_page => 10)
end
if params[:q]
@q = Recipe.search(params[:q])
@all_recipes = @q.result(distinct: true)
end
end
Run Code Online (Sandbox Code Playgroud)
然后我在表格中添加如下(食谱/索引):
<%= search_form_for @q do |f| %>
<%= f.label :name_cont %>
<%= f.text_field :name_cont %>
<%= f.submit %>
<% end %>
Run Code Online (Sandbox Code Playgroud)
我收到以下错误:
No Ransack::Search object was provided to search_form_for!
Run Code Online (Sandbox Code Playgroud)
在这一行:
<%= search_form_for @q do |f| %>
Run Code Online (Sandbox Code Playgroud)
这与安装有关吗?
小智 5
尼古拉斯是对的,错误仅来自@q
当请求包含“q”参数时才被初始化。这就是为什么在提交表单之前您会收到错误(没有“q”参数)。
解决这个问题的另一种方法是初始化@q
在你的 application_controller 中
def set_search
@q=Recipe.search(params[:q])
end
Run Code Online (Sandbox Code Playgroud)
在你的recipes_controller中
before_filter :set_search
仅当请求包含“q”参数时,@q 对象才会被初始化。
您应该尝试将操作索引减少为以下形式:
def index
@q = Recipe.search(search_params)
@recipes = @q.result(distinct: true).paginate(page: params[:page], per_page: 10)
end
private
def search_params
default_params = {}
default_params.merge({user_id_eq: current_user.id}) if signed_in?
# more logic here
params[:q].merge(default_params)
end
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
6585 次 |
最近记录: |