应用WillPaginate分页
- 博客分类:
- Ruby && RoR
WillPaginate这个插件很棒,以至于其取代了Rails中原有的Paginate方法,虽然看上其很简单,其实还是有不少技巧的,本篇用来记录我遇到的或者使用到的一些tips。
1.直接使用paginate
这个比较简单,也是使用的最多的,如下:
Ruby代码
- def self.get_all_items_in_catelog( catelog_id,page,per_page="10")
- paginate :per_page => per_page, :page => page,
- :conditions =>["catelog_id = ? and caiji > 0",catelog_id],
- :order => 'created_at DESC ,updated_at DESC'
- end
2.使用Model.paginate_by_sql
有的时候,你需要的SQL用Rails拼的时候有些不方便,这个时候可以考虑使用paginate_by_sql来实现,这个没啥好说的,你需要什么样的SQL直接写就可以了,例如:
#排行榜列表
Ruby代码
- def self.get_all_items_in_rank(rank_id, page,per_page="10")
- Book.paginate_by_sql ["SELECT DISTINCT `books`.* FROM `books` LEFT OUTER JOIN `ranksorts`
- ON (`books`.`prodid` = `ranksorts`.`prodid`) LEFT OUTER JOIN `ranks`
- ON (`ranks`.`id` = `ranksorts`.`rank_id`) WHERE (ranks.id = ?)
- ORDER BY books.updated_at DESC,books.created_at DESC", rank_id],
- :page => page, :per_page => per_page
- end
还有其他的一些小技巧,慢慢添加,你如果有类似的技巧,期待您的分享。。