太阳黑子与kaminari分页

时间:2011-10-28 12:37:00

标签: ruby-on-rails sunspot kaminari

我最近决定将我的索引引擎从sphinx移植到solr。使用kaminari和thinking_sphinx后,我决定尝试在太阳黑子https://github.com/sunspot/sunspot/pull/64 / https://github.com/sunspot/sunspot/pull/67中使用泛型分页,以避免移动到will_paginate。

我的搜索处理如下:

@search = Address.search do
  fulltext params[:search]
  with(:updated_at).greater_than(1.week.ago)
  order_by :updated_at, :desc
  paginate :page => params[:page], :per_page => 7
end

我的观点与使用thinking_sphinx时的观点相同:

<%= render :partial => 'address' %>
<%= paginate @addresses %>

我的问题是在更改后我在尝试执行搜索时不断收到以下错误:

undefined method `current_page' for []:Array

我正在使用最新版本的太阳黑子,据我所知应该让我使用kaminari:

Using sunspot (1.3.0.rc3) from git://github.com/sunspot/sunspot.git (at master) 
Using sunspot_rails (1.3.0.rc3) from git://github.com/sunspot/sunspot.git (at master) 

这与我的旧think_sphinx设置完美配合,所以我做错了什么?

1 个答案:

答案 0 :(得分:13)

这就是我使用的方式,而且效果很好

@search = Sunspot.search(Listing) do
      if params[:category].present?
        with :category_id, params[:category]
      end
      if params[:subcategory].present?
        with :subcategory_id, params[:subcategory]
      end
      if params[:q].present?
        keywords params[:q]  do 
          fields :title, :description
        end
      end
      paginate :page => params[:page], :per_page => SEARCH_RESULT_PER_PAGE
    end

在观点中我有这个

<%= paginate @search.hits %>