您的位置:首页 > 其它

分页插件之--will_paginage

2015-06-26 09:14 218 查看
正常分页: 在rails3中,用will_paginage有两种方式,第一种就是用plugin形式,安装方法: 这里有个wiki关于安装的说明,https://github.com/mislav/will_paginate/wiki/installation,这里我只是想说一下关于这个插件的配置参数。首先,如果你是用插件安装的,那么找到vendor/plugins/will_paginate/lib/will_paginate/view_helpers.rb,这个helper就是这个插件的关于现实的helper,  
@@pagination_options  =  {  : class   =>   ' pagination ' ,
: prev_label    =>   ' 上一页 ' ,   #这个一般是用在我们中文网站上的时候需要进行改动,默认是 << Previous
: next_label    =>   ' 下一页 ' ,   #这个一般是用在我们中文网站上的时候需要进行改动,默认是 Next >>
: inner_window  =>   4 ,   # inner_window  控制显示当前页临近的多少个链接 ,默认是4
: outer_window  =>   1 , # outer_window 控制显示首/末页临近的多少个链接,默认是1
:page_links => false, # 如果是false的时候,只显示上一页和下一页 (默认是 true)
: separator     =>   '   ' ,   # 这个参数是用来设置页码之间 的分隔符的,用空格或者(|)或者其他的都可以
: param_name    =>   : page ,   #这个参数是用来我们点击页码连接的时候传递的参数的名称,一般不用改动
:class           =>  'pagination' ,  #这个是用来给分页的元素家heml的类名的,可以通过这个类名进行样式布局。
}
    以上说的是你以插件的形式安装的,如果你用的而是rubygems形式安装的,那么这个配置你就需要到配置文件里面去改了,如果你的项目时2.x的,那么你的配置文件的改动应该是在config/environment.rb里面,加上类似于这样的几句,来进行相关的默认修改: 1. WillPaginate::ViewHelpers.pagination_options[ :class ] =  "yourclass"    2. WillPaginate::ViewHelpers.pagination_options[:previous_label ] =  "前一页"    3. WillPaginate::ViewHelpers.pagination_options[:next_label ] =  "后一页"           如果你的项目时3.0以上的版本的话,那么你的这个配置修改就要到 config/initalizer下新建一个文件(例如:will_paginate.rb),在这个文件里面加上类似于上面的三句的配置,来进行修改。 用法: 1、 在config文件中配置 gem ‘will_paginate’ 2、 (控制器)在要用到的分页功能的查询语句后面添加
:.paginate(:page => params[:page], :per_page => 3):page是页面接收的参数,:per_page是页面要显示记录数;
  3、页面在要显示的地方加上一句:<%= will_paginate @comments %>   下面是例子: AJAX分页: 1、在application_heler.rb文件中添加:     
def will_paginate_remote(paginator, options={})
function = options.delete(:after)
update = options.delete(:update)
url = options.delete(:url)
str = will_paginate(paginator, options)
=begin
if str != nil
str = str.gsub(/href="(.*?)"/) do
"href=\"#\" onclick=\"jQuery.ajax('#{(url ? url + $1.sub(/[^\?]*/, '') : $1)}',{
method: 'get',
dataType: 'html',
success: function(data){
alert('---------');
$('##{update}').html(data);

}
})\""
end.html_safe
end
=end
str.scan(/href="(.*?)"/).flatten.uniq.each do |a|
test_url = url ? url + a.sub(/[^\?]*/, '') : a
str.gsub!("href=\"#{a}\"") do
"href=\"#\" onclick=\"jQuery.ajax('#{test_url}',{
method: 'get',
dataType: 'html',
success: function(data){
$('##{update}').html(data);
}
})\""
end
end
str.html_safe
end

 

2、页面写法

 
<%= will_paginate_remote(@purchases, :update=>'admin_purchase_list', :params => params)%>
 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: