分页插件之--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)%>
相关文章推荐
- Rails使用will_paginate插件进行分页
- rails2.3.XX中使用will_paginate分页插件,并实现Ajax分页
- 如何向Ruby on Rails 分页插件 will_paginate 的链接插入其它参数
- Rails2中使用will_paginate插件实现分页(续)--- 更改样式
- rails2.3.XX中使用will_paginate分页插件,并实现Ajax分页
- Rails2中使用will_paginate插件进行分页
- Rails2中使用will_paginate插件实现分页
- 好用的分页插件 will_paginate
- ajax结合接口 分页插件
- 精心挑选的12款优秀 jQuery Ajax 分页插件和教程
- [前端插件]Bootstrap Table服务器分页与在线编辑应用总结
- Mybatis分页插件PageHelper使用
- Mybatis分页插件PageHelper的简单使用
- Js分页条 摆脱JQuery及JQuery分页插件的束缚
- 基于Metronic的Bootstrap开发框架经验总结(2)--列表分页处理和插件JSTree的使用
- 最实用的jQuery分页插件
- jquery pagination插件动态分页实例(Bootstrap分页)
- jquery分页插件
- 精心挑选的12款优秀 jQuery Ajax 分页插件和教程
- 源码来袭!!!基于jquery的ajax分页插件(demo+源码)