使用简单搜索与Kaminari分页宝石

时间:2012-11-23 17:22:44

标签: ruby-on-rails search kaminari

我正在尝试使用Kaminari将分页应用到我的rails应用程序。我还整合了一个基于Railscast Episode #37的简单搜索表单。当我尝试应用kaminari页面和每个方法时,我得到错误'未定义的方法页'。以下是我正在使用的代码。

posts_controller.rb

def index
  @posts = Post.search(params[:search]).page(params[:page]).per(2)
end

post.rb

def self.search(search)
  if search
    find(:all, conditions: ['title || body LIKE ?', "%#{search}%"], order: "created_at DESC")
  else
    find(:all)
  end
end

index.html.erb

<%= paginate @posts %>

当我删除分页时,搜索工作正常。当我删除搜索时,分页工作正常。我似乎无法使用它们并使代码正常运行。请告知我的代码中是否存在我遗漏的导致此操作无法正常工作的内容。

1 个答案:

答案 0 :(得分:9)

在您的情况下,您将从搜索方法返回数组对象而不是 ActiveRecord :: Relation 对象。

 find(:all, conditions: ...) # find method will return an array object.

在您的控制器中添加检查,

def index
  @posts = Post.search(params[:search])
  if @posts.class == Array
    @posts = Kaminari.paginate_array(@posts).page(params[:page]).per(10) 
  else
    @posts = @posts.page(params[:page]).per(10) # if @posts is AR::Relation object 
  end
end

Kaminari与数组https://github.com/amatsuda/kaminari#paginating-a-generic-array-object的分页

对于ActiveRecord :: Relation对象,请检查此http://railscasts.com/episodes/239-activerecord-relation-walkthrough