zoukankan      html  css  js  c++  java
  • 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啦~! 很快的吧~~








  • 相关阅读:
    JavaScript Object.prototype.toString 解析过程
    今天一定要纪念一下
    考验你的JavaScript底细
    2016-3-23
    记录一下最近的感受
    mac ox快捷键总结
    如何把开源的项目fork到自己的仓库并Down到本地
    使用vue-cli构建vue.js项目
    成为一名优秀的web前端工程师都需要做些什么?
    关于angularjs input上传图片前获取图片的Size 浅析
  • 原文地址:https://www.cnblogs.com/feichan/p/2257408.html
Copyright © 2011-2022 走看看