[Dynamic Language] Python Django: 模板引擎(4)在视图中使用模板和模板继承
2010-06-23 00:36
701 查看
Django 视图中使用模板
模板加载
首先设置 setting.py 文件的 TEMPLATE_DIRS ,告诉Django框架我们的模板文件存放的位置。
或
我们先看一个视图中使用模板的简单示例
在路由代码添加test路径
代码
在加载子模板时,模板引擎发现 {% extends %} 标签, 注意到该模板是一个子模板。模板引擎立即装载其父模板。此时,模板引擎注意到父模板中的 {% block %} 标签,并用子模板的内容替换这些 block 。子模板中没有定义的块,模板系统将使用在父模板中定义的值。 父模板 {% block %} 标签中的内容总是被当作一条退路。继承并不会影响到模板的上下文。 换句话说,任何处在继承树上的模板都可以访问到你传到模板中的每一个模板变量。
以下是使用模板继承的一些诀窍:
1、如果在模板中使用 {% extends %} ,必须保证其为模板中的第一个模板标记。 否则,模板继承将不起作用。
2、一般来说,基础模板中的 {% block %} 标签越多越好。记住,子模板不必定义父模板中所有的代码块,因此你可以用合理的缺省值对一些代码块进行填充,然后只对子模板所需的代码块进行(重)定义。 俗话说,钩子越多越好。
3、如果发觉自己在多个模板之间拷贝代码,你应该考虑将该代码段放置到父模板的某个 {% block %} 中。
4、如果你需要访问父模板中的块的内容,使用 {{ block.super }}这个标签吧,这一个魔法变量将会表现出父模板中的内容。 如果只想在上级代码块基础上添加内容,而不是全部重载,该变量就显得非常有用了。
5、不允许在同一个模板中定义多个同名的 {% block %} 。 存在这样的限制是因为block 标签的工作方式是双向的。 也就是说,block 标签不仅挖了一个要填的坑,也定义了在父模板中这个坑所填充的内容。如果模板中出现了两个相同名称的 {% block %} 标签,父模板将无从得知要使用哪个块的内容。
6、{% extends %} 对所传入模板名称使用的加载方法和 get_template() 相同。 也就是说,会将模板名称被添加到 TEMPLATE_DIRS 设置之后。
7、多数情况下, {% extends %} 的参数应该是字符串,但是如果直到运行时方能确定父模板名,这个参数也可以是个变量。 这使得你能够实现一些很酷的动态功能。
模板加载
首先设置 setting.py 文件的 TEMPLATE_DIRS ,告诉Django框架我们的模板文件存放的位置。
TEMPLATE_DIRS = ( '/home/django_test/mysite/templates', //模板存放目录 )
或
import os.path TEMPLATE_DIRS = ( os.path.join(os.path.dirname(__file__), 'templates').replace('\\','/'), )
我们先看一个视图中使用模板的简单示例
在路由代码添加test路径
代码
1 {% extends "theme1/base.html"%} 2 3 {% block title %} test template used {% endblock %} 4 5 {% block content%} 6 7 {% ifequal name name %} 8 <p> welcome {{ name|upper }} and {{ name1|lower|upper }}</p> 9 {% else %} 10 <p> the name != name1 </p> 11 {% endifequal %} 12 13 {% comment %} 14 <ul> 15 {% if namelist %} 16 {% for name in namelist %} 17 <li> {{ name }} </li> 18 {% for subname in name %} 19 <li>{{ subname }}</li> 20 {% endfor %} 21 {% endfor %} 22 {% else %} 23 the namelist is empty. 24 {% endif %} 25 </ul> 26 {% endcomment %} 27 28 <ul> 29 {% for name in namelist %} 30 {% if forloop.first %} 31 this first name is : {{ name }}</br> 32 {% endif %} 33 {{ forloop.counter }} : {{ name }} 34 35 {% for subname in name %} 36 <li>{{ subname }}</li> 37 {% endfor %} 38 39 {% if forloop.last %} 40 this last name is : {{ name }} </br> 41 {% endif %} 42 {% empty %} 43 the namelist is empty. 44 {% endfor %} 45 </ul> 46 47 {% endblock %}
在加载子模板时,模板引擎发现 {% extends %} 标签, 注意到该模板是一个子模板。模板引擎立即装载其父模板。此时,模板引擎注意到父模板中的 {% block %} 标签,并用子模板的内容替换这些 block 。子模板中没有定义的块,模板系统将使用在父模板中定义的值。 父模板 {% block %} 标签中的内容总是被当作一条退路。继承并不会影响到模板的上下文。 换句话说,任何处在继承树上的模板都可以访问到你传到模板中的每一个模板变量。
以下是使用模板继承的一些诀窍:
1、如果在模板中使用 {% extends %} ,必须保证其为模板中的第一个模板标记。 否则,模板继承将不起作用。
2、一般来说,基础模板中的 {% block %} 标签越多越好。记住,子模板不必定义父模板中所有的代码块,因此你可以用合理的缺省值对一些代码块进行填充,然后只对子模板所需的代码块进行(重)定义。 俗话说,钩子越多越好。
3、如果发觉自己在多个模板之间拷贝代码,你应该考虑将该代码段放置到父模板的某个 {% block %} 中。
4、如果你需要访问父模板中的块的内容,使用 {{ block.super }}这个标签吧,这一个魔法变量将会表现出父模板中的内容。 如果只想在上级代码块基础上添加内容,而不是全部重载,该变量就显得非常有用了。
5、不允许在同一个模板中定义多个同名的 {% block %} 。 存在这样的限制是因为block 标签的工作方式是双向的。 也就是说,block 标签不仅挖了一个要填的坑,也定义了在父模板中这个坑所填充的内容。如果模板中出现了两个相同名称的 {% block %} 标签,父模板将无从得知要使用哪个块的内容。
6、{% extends %} 对所传入模板名称使用的加载方法和 get_template() 相同。 也就是说,会将模板名称被添加到 TEMPLATE_DIRS 设置之后。
7、多数情况下, {% extends %} 的参数应该是字符串,但是如果直到运行时方能确定父模板名,这个参数也可以是个变量。 这使得你能够实现一些很酷的动态功能。
相关文章推荐
- django在视图中使用模板
- python Django模板的使用方法(图文)
- Django之模板继承与ajax使用错误处理~
- Python3之Django Web框架模板继承篇
- Python笔记(五)--Django中使用模板
- Django之视图与模板以及在模板中使用bootstrap
- 六、Python Django模板使用流程
- python Django模板的使用方法(图文)
- Python系列视频教程: Django【13讲】第六讲 模板基本使用
- python web框架Django学习(五)模板中的循环,条件判断,常用的标签,过滤器的使用
- python Django模板的使用方法
- python下的web开发框架-Django,django模板的使用
- python下的web开发框架-Django,django模板的使用
- [Dynamic Language] Python Django: 模板引擎(1)基本使用
- django在视图中使用模板
- 【PythonDjango后台实例 第三章】Python3.6.1+Django1.8 模版的继承使用
- python Django模板的使用方法
- [Django模板系统]在视图中使用模板
- Django模板-在视图中使用模板
- Django模板继承block区域中如果要使用staic文件,需要在block区域再次导入