Liquid は素晴らしいテンプレート システムだと思います。調査/使用おめでとうございます。
デフォルトでは、モデルのメソッドはいずれも Liquid テンプレートで使用できません。これは良いことです。次に、使用できるメソッドを指定します。(ホワイトリスト)
メーリング リストで送信された Module の拡張機能を使用します。完全な拡張は以下です。クラスとモジュールに単純な #liquid_methods メソッドを追加することで、Liquid::Drop の作成を処理します。
次に、モデルで次のようにします。
class Blog
# id
# name
has_many :posts
def latest_posts(n)
posts.latest(n) # using a named scope
end
def latest_10_posts;latest_posts(10); end
liquid_methods :id, :name, :posts, :latest_10_posts
end
パラメータをドロップに渡す方法/かどうかはわかりません。Liquidメーリングリストで質問してください。できると思います。
追加:あなたの質問を読み直したところ、本当にそのパラメータをメソッドに送信したいことがわかりました。複数の引数/パラメーターを Liquid フィルターに送信できます。したがって、フィルターを使用できます。
# Define as a Liquid filter
def latest_posts(blog, n)
blog.latest(n)
end
# then call the filter in a template:
{{ blog2 | latest_posts: 10 }}
# Note that the second param is after the filter name.
この例では、Post クラスでもリキッド メソッドを宣言する必要があることに注意してください。
これがモジュール拡張です。
# By dd -- http://groups.google.com/group/liquid-templates/browse_thread/thread/bf48cfebee9fafd9
# This extension is usesd in order to expose the object of the implementing class
# to liquid as it were a Drop. It also limits the liquid-callable methods of the instance
# to the allowed method passed with the liquid_methods call
# Example:
#
# class SomeClass
# liquid_methods :an_allowed_method
#
# def an_allowed_method
# 'this comes from an allowed method'
# end
# def unallowed_method
# 'this will never be an output'
# end
# end
#
# if you want to extend the drop to other methods you can define more methods
# in the class <YourClass>::LiquidDropClass
#
# class SomeClass::LiquidDropClass
# def another_allowed_method
# 'and this is another allowed method'
# end
# end
# end
#
# usage:
# @something = SomeClass.new
#
# template:
# {{something.an_allowed_method}}{{something.unallowed_method}}{{something.another_allowed_method}}
#
# output:
# 'this comes from an allowed method and this is another allowed method'
#
# You can also chain associations, by adding the liquid_method calls in the
# association models.
#
class Module
def liquid_methods(*allowed_methods)
drop_class = eval "class #{self.to_s}::LiquidDropClass < Liquid::Drop; self; end"
define_method :to_liquid do
drop_class.new(self)
end
drop_class.class_eval do
allowed_methods.each do |sym|
define_method sym do
@object.send sym
end
end
def initialize(object)
@object = object
end
end
end
end