时间:2021-05-22
新版本的will_paginate已经抛弃了这样的做法,转而使用gem的方式,本文通过建立一个名为foobar的应用来了解一下will_paginate的用法。
==============================
C:\>rails foobar -d mysql
C:\>cd foobar
C:\foobar>ruby script/generate scaffold article title:string content:text
此时设置一下数据库(C:\foobar\config\database.yml),并且确保相关数据库已经建立好了。
C:\foobar>rake db:migrate
C:\foobar>ruby script/server
此时,http://localhost:3000/articles可以浏览了,添加一些数据(比如十条),为分页做准备。
===============================
plugin形式的旧版will_paginate不用在rails程序里显式的加载,这是因为rails启动时会自动执行插件目录下的init.rb文件,而新版will_pagiante采用的是gem形式,没有这样的机制,所以需要在rails程序里显式的加载:
# C:\foobar\config\environment.rb
Rails::Initializer.run do |config|
config.gem 'mislav-will_paginate', :version => '~> 2.3.2', :lib => 'will_paginate',
:source => 'http://gems.github.com'
end
此时,重启一下WEBrick,然后执行如下命令安装相应的gem:
C:\foobar>rake gems:install
安装就完成了。
修改控制器的index方法,加上类似下面的代码:
# C:\foobar\app\controllers\articles_controller.rb
@articles = Article.paginate :page => params[:page], :per_page => 2
修改对应的模板文件,加上类似下面的代码:
# C:\foobar\app\views\articles\index.html.erb
<%= will_paginate @articles %>
再次重启一下WEBrick,然后浏览就可能看到分页效果了。
===============================
will_paginate的最新文档:http://github.com/mislav/will_paginate/wikis
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
统计关联数量,单个用法$posts=Post::withCount('comments')->orderBy('id','desc')->paginate(6)
在规则引擎中,Ruby的闭包使用特别频繁,而且有block,Proc和lambda等后几种形式的用法,很让人困惑。为了深入理解代码,再次认真学习了一下Ruby的
参数paginate(每页数量,是否简洁分页,分页参数)使用方式$list=db('user')->paginate(10);自定义参数传参$list=db('
安装Ruby和Gem下载rubywgethttps://cache.ruby-lang.org/pub/ruby/2.3/ruby-2.3.8.tar.gz解压
Ruby的安装可以去Ruby的官方网站下载Ruby1.56的Windows安装包,安装安毕后,打开Dos窗口,输入ruby-v显示ruby1.8.6(2007-