应用WillPaginate分页

本文介绍了Rails中WillPaginate插件的实用技巧,包括直接使用paginate方法进行分页及利用Model.paginate_by_sql实现复杂SQL分页。

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

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、付费专栏及课程。

余额充值