问题描述
为了对公共数组进行分页,我得到了这个解决方案,
For paginating a common array I got this solution,
@arr_name =Kaminari.paginate_array(@arr_name).page(params[:page]).per(PER_PAGE_RECORDS)
PER_PAGE_RECORDS
是一个变量,其值根据分页需要.
PER_PAGE_RECORDS
is a variable with value as per needed for pagination.
有更好的想法吗??
也有一个使用分页的ajax调用,可以使用这个,
Also to have an ajax call for using pagination one can use this,
在您看来,
为您的 div 标签提供 id
give id to your div tab
div id="paginate"
在里面
true %>
并在js响应文件中放入,
And in js response file put,
$('#paginate').html('<%= escape_javascript(paginate(@arr_name, :remote)=> true).to_s) %>');
所以您的请求将是 AJAX.
So your requests will be AJAX.
谢谢.
推荐答案
这是使用 Kaminari 对数组对象进行分页的唯一可用辅助方法.另一种选择是,作为 kaminari wiki 页面 中建议的解决方案,将实例方法添加到数组对象.
This is the only available helper method to paginate an array object using Kaminari. Another alternative is, as suggested solution in kaminari wiki page, add the instance methods to the array object.
如果您正在尝试基于 ActiveModel 返回类型(.all 返回数组,.where 返回 ARL)的通用解决方案,那么以下是一种解决方法.
If you are trying a common solution based on the ActiveModel return type ( .all returns array and .where returns ARL) then following is an workaround.
unless @arr_name.kind_of?(Array)
@arr_name = @arr_name.page(params[:page]).per(PER_PAGE_RECORDS)
else
@arr_name = Kaminari.paginate_array(@arr_name).page(params[:page]).per(PER_PAGE_RECORDS)
end
这篇关于rails 3,Kaminari 对简单数组的分页的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!