rails2.3.XX中使用will_paginate分页插件,并实现Ajax分页
早在rails1.XX中,分页插件是内置的辅助方法,但进入rails2后,该方法已经被废除,改成插件的形式使用。
我使用的环境是winxp + ruby1.8.7 + rails 2.3.14。(抱怨一下下:win下开发rails是一件灰常灰常灰常痛苦的事情,T.T)
安装
will_paginate插件有两种安装方式:
一种是作为gem安装,gem install mislav-will_paginate,安装成功后在environment.rb文件中加上
config.gem 'mislav-will_paginate','2.3.15'
后面的2.3.15是安装的版本,自己看一下什么版本写上就ok;
另外一种安装方式是作为插件安装:
在https://github.com/mislav/will_paginate/tags中友各种版本的will_paginate插件,下载的时候要看好了,如果像我这样使用rails2的就不要下载最新的,那是rails3下使用的。下载下来后解压到vendor/plugins中,重命名为will_paginate就OK啦!
使用
在controller中将原来的
@products = Product.all
替换为
@products = Product.paginate(:page=>params[:page],:per_page=>3)
其中params[:page]是传回的参数,表明是第几页,:per_page是每页显示几条信息。
然后再view中加上
<%= will_paginate @products %>
就OK了。
实现Ajax分页
在插件中找到view_helpers.rb文件,添加代码
def will_paginate_remote(paginator, options={})
update = options.delete(:update)
url = options.delete(:url)
str = will_paginate(paginator, options)
if str != nil
str.gsub(/href="(.*?)"/) do
"href=\"#\" onclick=\"new Ajax.Updater('" + update + "', '" + (url ? url + $1.sub(/[^\?]*/, '') : $1) +
"', {asynchronous:true, evalScripts:true, method:'get'}); return false;\""
end
end
end
并在页面中加入
<%= javascript_include_tag :defaults %>
然后讲原来的
<%= will_paginate @products %>
修改为
<%= will_paginate_remote (@blogs,:update=>'blogs',:url=>nil)%>
就OK啦~! 很快的吧~~