`
johnnyhg
  • 浏览: 342500 次
  • 来自: NA
社区版块
存档分类
最新评论

应用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   

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

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics