Django模板引擎有几种-创新互联
这篇文章将为大家详细讲解有关Django模板引擎有几种,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
为猇亭等地区用户提供了全套网页设计制作服务,及猇亭网站建设行业解决方案。主营业务为网站设计、成都网站设计、猇亭网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!在Django框架中,可以使用两种模板引擎,一种是默认的Django模板引擎,还有一种是Jinja2模板引擎;
1.模版引擎的作用和优点
模版引擎作用是将View视图中需要在前端HTML页面中展示的数据,通过模板引擎的语法规则,展示出来;
模版引擎优点是将业务逻辑的Python代码和页面设计的HTML代码分离,使代码更干净整洁更容易维护,使Python程序员和HTML/CSS程序员分开协作,提高生产的效率,且将HTML代码分离出来,还能使其能够复用;
2.HTML模板存放的位置
HTML模板存放的位置有两个,一个是存放在settings文件中指定的DIRS的目录列表中,还有一个是直接在对应的APP包下,创建templates目录,将HTML放置于此即可,不同APP对其他APP目录下的templates目录都是可见的;
3.模板引擎的配置
先在项目的settings.py文件中找到TEMPLATES变量,然后加入
TEMPLATES = [ { # 选择模板引擎,默认是Django的模板引擎 'BACKEND': 'django.template.backends.django.DjangoTemplates', #或者是jinja2模版 'BACKEND': 'django.template.backends.jinja2.Jinja2' # 指定HTML模板存放的目录,如果HTML模板较多,可以设置多个模板路径 'DIRS': [os.path.join(BASE_DIR, 'templates')], # APP_DIRS的值判断是否支持将template目录放置在APP中,Django默认支持值为True 'APP_DIRS': True, 'OPTIONS': { 'context_processors': [ 'django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages', ], }, }, ]
4.Django模板引擎的模板语法
变量(VARIABLE):
{{ VARIABLE }} # 用于引入后台传入的变量 {{ VARIABLE.name }} {{ VARIABLE.age }}
标签(TAG):
{% TAG %} # 用于循环 1: 正序 for 循环 {% for item in items %}{{ forloop.counter }}
{{ item.name }}
{{ item.desc }}
{% endfor %} 2: 倒叙 for 循环 {% for item in items reversed %}{{ forloop.counter }}
# 记录循环到第几次,计数从1开始{{ item.name }}
{{ item.desc }}
{% endfor %} 3: 变量字典 {% for k,v in dictionary.items %}{{ k }},{{ v}}
{% endfor %}
5.Django模板的继承的作用
在Django开发过程中,页面中的重复部分,可以通过Django的模板继承来完成,这样使得页面开发和管理更简单;
在HTML页面中使用到的关键字:
{% extends 这里填写被继承的HTML页面 %} {% block 这里填写继承的block %} {% endblock %} {% include 这里填写需要引入的HTML子页面 %}
6.如何实现继承模板
我们知道了模板可以用继承的方式来实现复用,那接下来我们一起来操作一下:
第一步:可以在项目的templates中先编写好一个html页面,作为网站的基础页面被其他页面继承,我的HTML页面为base.html,然后在其中编辑HTML代码,注意要修改的部分写在{% block %} {% endblock %}的中间;
今天是星期几呀
今天是星期一
第二步:在你想要的app的templates目录下创建一个html页面,继承之前的基础页面,我还是使用的courses app,创建一个python.html文件,这些名字都可以自己命名的,不过要注意路径之类的;
{% extends 'base.html' %} {% block content %}今天是星期{{ week_id }}