详解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使用metaclass实现Singleton模式的方法
May 05 Python
Python中利用Scipy包的SIFT方法进行图片识别的实例教程
Jun 03 Python
python基础教程之分支、循环简单用法
Jun 16 Python
python实现二叉查找树实例代码
Feb 08 Python
python 3.74 运行import numpy as np 报错lib\site-packages\numpy\__init__.py
Oct 06 Python
django 中使用DateTime常用的时间查询方式
Dec 03 Python
使用PyWeChatSpy自动回复微信拍一拍功能的实现代码
Jul 02 Python
详解查看Python解释器路径的两种方式
Oct 15 Python
Django中ORM的基本使用教程
Dec 22 Python
如何用Python编写一个电子考勤系统
Feb 08 Python
Python3+Django get/post请求实现教程详解
Feb 16 Python
Python 视频画质增强
Apr 28 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
分享一个php 的异常处理程序
2014/06/22 PHP
php使用pdo连接并查询sql数据库的方法
2014/12/24 PHP
Zend Framework使用Zend_Loader组件动态加载文件和类用法详解
2016/12/09 PHP
给文字加上着重号的JS代码
2013/11/12 Javascript
JS小游戏之极速快跑源码详解
2014/09/25 Javascript
Jquery中find与each方法用法实例
2015/02/04 Javascript
JavaScript DSL 流畅接口(使用链式调用)实例
2015/03/15 Javascript
jQuery下拉美化搜索表单效果代码分享
2015/08/25 Javascript
jQuery实现可高亮显示的二级CSS菜单效果
2015/09/01 Javascript
JavaScript保留关键字汇总
2015/12/01 Javascript
JS中Json数据的处理和解析JSON数据的方法详解
2016/06/29 Javascript
一个简单的JavaScript Map实例(分享)
2016/08/03 Javascript
vue实现的上传图片到数据库并显示到页面功能示例
2018/03/17 Javascript
浅谈node中的cluster集群
2018/06/02 Javascript
Vue常见面试题整理【值得收藏】
2018/09/20 Javascript
javascript中关于类型判断的一些疑惑小结
2018/10/14 Javascript
vue中的循环对象属性和属性值用法
2020/09/04 Javascript
js通过canvas生成图片缩略图
2020/10/02 Javascript
js canvas实现五子棋小游戏
2021/01/22 Javascript
[01:01:51]EG vs VG Supermajor小组赛B组 BO3 第二场 6.2
2018/06/03 DOTA
[01:02:34]TFT vs VGJ.T Supermajor 败者组 BO3 第二场 6.5
2018/06/06 DOTA
python获取目录下所有文件的方法
2015/06/01 Python
python中实现将多个print输出合成一个数组
2018/04/19 Python
TensorFlow数据输入的方法示例
2018/06/19 Python
python 检查数据中是否有缺失值,删除缺失值的方式
2019/12/02 Python
python+adb命令实现自动刷视频脚本案例
2020/04/23 Python
python中id函数运行方式
2020/07/03 Python
解决HTML5中的audio在手机端和微信端的不能自动播放问题
2019/11/04 HTML / CSS
全球速卖通巴西站点:Aliexpress巴西
2016/08/24 全球购物
欧洲最大的笔和书写专家:The Pen Shop
2017/03/19 全球购物
英国布鲁姆精品店:Bloom Boutique
2018/03/01 全球购物
澳大利亚最大的百货公司:Myer
2018/12/21 全球购物
奥地利体育网上商店:Gigasport
2019/10/09 全球购物
求职简历自我评价2015
2015/03/10 职场文书
vue使用v-model进行跨组件绑定的基本实现方法
2021/04/28 Vue.js
MySQL令人大跌眼镜的隐式转换
2021/08/23 MySQL