所以我有一些帖子,想展现ñ .. 中号在侧边栏最新的条目(这些数字在配置设定)
我可以轻松地获得最新的n条记录
class Post < ActiveRecord::Base
default_scope :order => "created_at DESC"
scope :published, lambda { where("blog_entries.created_at <= ?", Time.zone.now) }
scope :latest, lambda { |n| published.limit(n) }
end
@posts = Post.latest(6)
Run Code Online (Sandbox Code Playgroud)
但我想要的是
@posts = Post.published.limit(6, 12)
Run Code Online (Sandbox Code Playgroud)
但是这给了wrong number of arguments,AR中有什么方法吗?现在我正在玩will_paginate,但看起来很难用它.
Rob*_*bin 21
好的,答案是,我认为:
@posts = Post.published.limit(6).offset(5)
Run Code Online (Sandbox Code Playgroud)
它将从第六个开始检索6个帖子.
edit2:关于极限([6,12]),我觉得很奇怪:
attr_accessor :limit_value
def limit(value)
relation = clone
relation.limit_value = value
relation
end
def build_arel
...
arel.take(connection.sanitize_limit(@limit_value)) if @limit_value
...
end
def sanitize_limit(limit)
if limit.is_a?(Integer) || limit.is_a?(Arel::Nodes::SqlLiteral)
limit
elsif limit.to_s =~ /,/
Arel.sql limit.to_s.split(',').map{ |i| Integer(i) }.join(',')
else
Integer(limit)
end
end
Run Code Online (Sandbox Code Playgroud)
所以我真的不知道它如何与数组一起工作.但我显然错过了一些东西.你看到了什么?