分页插件之--will_paginage

阅读更多
正常分页:
在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)%>
 

你可能感兴趣的:(rails,will_paginage)