個人的には、ビューを介して本をコンテキスト変数として渡すだけです。そうすれば、テンプレート タグは必要ありません。
別の方法として、inclusion_tag デコレーターを代わりに使用することもできます。これは、現在のドキュメントにカスタム コンテキストを持つインクルード テンプレートをレンダリングするというアイデアをまとめたものです。
しかし、現在のパスを続行したい場合は、simple_tag
デコレータは適していません。string
テンプレートに直接レンダリングしたいを返す必要がある場合に使用します。あなたがやろうとしているのは、テンプレート コンテキスト変数を設定することです。これは少し複雑ですが、それほど難しくありません。次のようなノードを作成します。
class LastBooksNode(template.Node):
def __init__(self, category, cutoff=5, var_name='books'):
self.category = category
self.cutoff = cutoff
self.var_name = var_name
def render(self, context):
context[self.var_name] = Books.objects.filter(category=self.category)[:self.cutoff]
return ''
@register.tag(name='last_books')
def do_last_books(parser, token):
error = False
try:
tag_name, category, cutoff, _as, var_name = token.split_contents()
if _as != 'as':
error = True
except:
error = True
if error:
raise TemplateSyntaxError, 'last_books must be of the form, "last_books <category> <cutoff> as <var_name>"'
else:
return LastBooksNode(a_cat, cutoff, var_name)
次に、テンプレート タグを次のように呼び出します。
{% import <your tag library> %}
{% last_books 'category' 5 as my_books %}
{% for book in my_books %}
....
{% endfor %}
テストされていませんが、これがアイデアを示していることを願っています。ただし、前述のように、複数の場所でこれを再利用するつもりがない場合は、コンテキストを介してブックをビューに直接渡すか、includes_tag を使用する方が簡単な場合があります。