详解Python的Django框架中inclusion_tag的使用
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了详解Python的Django框架中inclusion_tag的使用,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2017字,纯文字阅读大概需要3分钟。
内容图文
![详解Python的Django框架中inclusion_tag的使用](/upload/InfoBanner/zyjiaocheng/437/0c49ea1517c94faebb3f64d997e7daa4.jpg)
这些排序标签被称为 包含标签 。如何写包含标签最好通过举例来说明。 让我们来写一个能够产生指定作者对象的书籍清单的标签。 我们将这样利用标签:
{% books_for_author author %}
结果将会像下面这样:
- The Cat In The Hat
- Hop On Pop
- Green Eggs And Ham
首先,我们定义一个函数,通过给定的参数生成一个字典形式的结果。 需要注意的是,我们只需要返回字典类型的结果就行了,不需要返回更复杂的东西。 这将被用来作为模板片段的内容:
def books_for_author(author): books = Book.objects.filter(authors__id=author.id) return {'books': books}
接下来,我们创建用于渲染标签输出的模板。 在我们的例子中,模板很简单:
-
{% for book in books %}
- {{ book.title }} {% endfor %}
最后,我们通过对一个 Library 对象使用 inclusion_tag() 方法来创建并注册这个包含标签。
在我们的例子中,如果先前的模板在 polls/result_snippet.html 文件中,那么我们这样注册标签:
register.inclusion_tag('book_snippet.html')(books_for_author)
Python 2.4装饰器语法也能正常工作,所以我们可以这样写:
@register.inclusion_tag('book_snippet.html') def books_for_author(author): # ...
有时候,你的包含标签需要访问父模板的context。 为了解决这个问题,Django为包含标签提供了一个 takes_context 选项。 如果你在创建模板标签时,指明了这个选项,这个标签就不需要参数,并且下面的Python函数会带一个参数: 就是当这个标签被调用时的模板context。
例如,你正在写一个包含标签,该标签包含有指向主页的 home_link 和 home_title 变量。 Python函数会像这样:
@register.inclusion_tag('link.html', takes_context=True) def jump_link(context): return { 'link': context['home_link'], 'title': context['home_title'], }
(注意函数的第一个参数 必须 是 context 。)
模板 link.html 可能包含下面的东西:
Jump directly to {{ title }}.
然后您想使用自定义标签时,就可以加载它的库,然后不带参数地调用它,就像这样:
{% jump_link %}
内容总结
以上是互联网集市为您收集整理的详解Python的Django框架中inclusion_tag的使用全部内容,希望文章能够帮你解决详解Python的Django框架中inclusion_tag的使用所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。