应用WillPaginate分页

本文详细介绍了WillPaginate插件在Ruby/RoR框架中的使用技巧,包括基本的paginate方法和更复杂的paginate_by_sql方法。提供了实例代码和一些实用的小技巧,帮助开发者更好地理解和运用分页技术。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

应用WillPaginate分页

WillPaginate这个插件很棒,以至于其取代了Rails中原有的Paginate方法,虽然看上其很简单,其实还是有不少技巧的,本篇用来记录我遇到的或者使用到的一些tips。

1.直接使用paginate
这个比较简单,也是使用的最多的,如下:

Ruby代码
  1. def self.get_all_items_in_catelog( catelog_id,page,per_page="10")  
  2.   paginate :per_page => per_page, :page => page,  
  3.     :conditions =>["catelog_id = ? and caiji > 0",catelog_id],  
  4.     :order => 'created_at DESC ,updated_at  DESC'  
  5. end 

 2.使用Model.paginate_by_sql
有的时候,你需要的SQL用Rails拼的时候有些不方便,这个时候可以考虑使用paginate_by_sql来实现,这个没啥好说的,你需要什么样的SQL直接写就可以了,例如:
  #排行榜列表

Ruby代码
  1. def self.get_all_items_in_rank(rank_id, page,per_page="10")  
  2.     Book.paginate_by_sql ["SELECT DISTINCT `books`.* FROM `books` LEFT OUTER JOIN `ranksorts`
  3. ON (`books`.`prodid` = `ranksorts`.`prodid`) LEFT OUTER JOIN `ranks` 
  4. ON (`ranks`.`id` = `ranksorts`.`rank_id`) WHERE (ranks.id = ?)
  5. ORDER BY books.updated_at DESC,books.created_at DESC", rank_id],  
  6.       :page => page, :per_page => per_page  
  7. end  

还有其他的一些小技巧,慢慢添加,你如果有类似的技巧,期待您的分享。。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值