详解Python的Django框架中inclusion_tag的使用


Posted in Python onJuly 21, 2015

另外一类常用的模板标签是通过渲染 其他 模板显示数据的。 比如说,Django的后台管理界面,它使用了自定义的模板标签来显示新增/编辑表单页面下部的按钮。 那些按钮看起来总是一样的,但是链接却随着所编辑的对象的不同而改变。 这就是一个使用小模板很好的例子,这些小模板就是当前对象的详细信息。

这些排序标签被称为 包含标签 。如何写包含标签最好通过举例来说明。 让我们来写一个能够产生指定作者对象的书籍清单的标签。 我们将这样利用标签:

{% books_for_author author %}

结果将会像下面这样:

<ul>
  <li>The Cat In The Hat</li>
  <li>Hop On Pop</li>
  <li>Green Eggs And Ham</li>
</ul>

首先,我们定义一个函数,通过给定的参数生成一个字典形式的结果。 需要注意的是,我们只需要返回字典类型的结果就行了,不需要返回更复杂的东西。 这将被用来作为模板片段的内容:

def books_for_author(author):
  books = Book.objects.filter(authors__id=author.id)
  return {'books': books}

接下来,我们创建用于渲染标签输出的模板。 在我们的例子中,模板很简单:

<ul>
{% for book in books %}
  <li>{{ book.title }}</li>
{% endfor %}
</ul>

最后,我们通过对一个 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 <a href="{{ link }}">{{ title }}</a>.

然后您想使用自定义标签时,就可以加载它的库,然后不带参数地调用它,就像这样:

{% jump_link %}
Python 相关文章推荐
Python使用random和tertools模块解一些经典概率问题
Jan 28 Python
Python生成器(Generator)详解
Apr 13 Python
Python中的super用法详解
May 28 Python
Python如何实现MySQL实例初始化详解
Nov 06 Python
django允许外部访问的实例讲解
May 14 Python
Python----数据预处理代码实例
Mar 20 Python
Python Multiprocessing多进程 使用tqdm显示进度条的实现
Aug 13 Python
Python hashlib常见摘要算法详解
Jan 13 Python
Python多重继承之菱形继承的实例详解
Feb 12 Python
解决python3输入的坑——input()
Dec 05 Python
用python-webdriver实现自动填表的示例代码
Jan 13 Python
宝塔更新Python及Flask项目的部署
Apr 11 Python
剖析Django中模版标签的解析与参数传递
Jul 21 #Python
Python简单调用MySQL存储过程并获得返回值的方法
Jul 20 #Python
在Django的上下文中设置变量的方法
Jul 20 #Python
在Django中编写模版节点及注册标签的方法
Jul 20 #Python
在Python的Django框架中编写编译函数
Jul 20 #Python
Python的Django框架中自定义模版标签的示例
Jul 20 #Python
详解在Python的Django框架中创建模板库的方法
Jul 20 #Python
You might like
《OVERLORD》第四季,终于等到你!
2020/03/02 日漫
php 缓存函数代码
2008/08/27 PHP
提高define性能的php扩展hidef的安装和使用
2011/06/14 PHP
destoon整合ucenter后注册页面不跳转的解决方法
2014/06/21 PHP
详谈PHP中的密码安全性Password Hashing
2017/02/04 PHP
JQuery实现倒计时按钮的实现代码
2012/03/23 Javascript
jquery中插件实现自动添加用户的具体代码
2013/11/15 Javascript
iframe窗口高度自适应的又一个巧妙实现思路
2014/04/04 Javascript
jQuery操作select下拉框的text值和value值的方法
2014/05/31 Javascript
JavaScript字符串对象charAt方法入门实例(用于取得指定位置的字符)
2014/10/17 Javascript
JavaScript使用setInterval()函数实现简单轮询操作的方法
2015/02/02 Javascript
JavaScript子窗口调用父窗口变量和函数的方法
2015/10/09 Javascript
jQuery检测滚动条是否到达底部
2015/12/15 Javascript
Easyui Treegrid改变默认图标的方法
2016/04/29 Javascript
node.js从数据库获取数据
2016/05/08 Javascript
微信小程序开发经验总结(推荐)
2017/01/11 Javascript
Angular模板表单校验方法详解
2017/08/11 Javascript
JScript实现表格的简单操作
2017/08/15 Javascript
解决微信二次分享不显示摘要和图片的问题
2017/08/18 Javascript
JS实现数组深拷贝的方法分析
2019/03/06 Javascript
ES6 Promise对象的应用实例分析
2019/06/27 Javascript
vue 实现微信浮标效果
2019/09/01 Javascript
使用相同的Apache实例来运行Django和Media文件
2015/07/22 Python
Python正则表达式教程之三:贪婪/非贪婪特性
2017/03/02 Python
python访问抓取网页常用命令总结
2017/04/11 Python
Python Socket编程之多线程聊天室
2018/07/28 Python
Python中GeoJson和bokeh-1的使用讲解
2019/01/03 Python
Python 求向量的余弦值操作
2021/03/04 Python
HTML5在线预览PDF的示例代码
2017/09/14 HTML / CSS
触发器(trigger)的功能都有哪些?写出一个触发器的例子
2012/09/17 面试题
求职简历推荐信范文
2013/12/02 职场文书
党员创先争优活动总结
2014/05/04 职场文书
2014年高三班主任工作总结
2014/12/05 职场文书
工人先进事迹材料
2014/12/26 职场文书
拾金不昧表扬稿大全
2015/05/05 职场文书
Redis入门教程详解
2021/08/30 Redis