在Django中,有自带的模板引擎DjangoTemplates
用来渲染模板,使用Django的模版语言,叫做DTL,Jinja2也是十分常见的模板渲染引擎,Django对Jinja2也提供了支持,那么如何将你的Django项目配置成使用Jinja2引擎呢?
安装Jinja2
首先,需要在当前环境中安装Jinja2: pip install jinja2
可以通过pip list
查看当前python环境中安装的模块。
配置文件
Django的配置,一般是放在settings.py
文件中,模板的配置也在此文件中,如果你是使用Django-admin startproject project_name
来创建的项目的话,配置文件的默认路径为: ./project_name/project_name/settings.py
在配置文件中找到如下代码:
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [],
'APP_DIRS': True,
'OPTIONS': {
# ... some options here ...
},
},
]
复制代码
- 字段解释
BACKEND
: 即配置的后端模板引擎DIRS
:默认为空列表,引擎搜索模板文件的路径APP_DIRS
:默认为True
(使用Django-admin startproject
创建),表示引擎是否去已安装的app路径下去搜索模板文件。
这段代码即为Django默认生成的模板配置。所以,将引擎替换成Jinja2的第一步,就是修改这一段配置:
TEMPLATES = [
{
'BACKEND': 'django.template.backends.jinja2.Jinja2',
'DIRS': [],
'APP_DIRS': True,
'OPTIONS': {
# ... some options here ...
},
},
]
复制代码
OPTIONS
使用Jinja2时,需要在OPTIONS字段中,添加环境变量的路径,以使得模版API可以统一起来,你可以创建这样一个文件project_name/jinja2.py
,内容如下:
from django.contrib.staticfiles.storage import staticfiles_storage
from django.urls import reverse
from jinja2 import Environment
def environment(**options):
env = Environment(**options)
env.globals.update({
'static': staticfiles_storage.url,
'url': reverse,
})
return env
复制代码
并且在options中添加如下代码:
TEMPLATES = [
{
'BACKEND': 'django.template.backends.jinja2.Jinja2',
'DIRS': [],
'APP_DIRS': True,
'OPTIONS': {
# ... some options here ...
‘project_name.jinja2.environment’
},
},
]
复制代码
至此,就可以在项目中愉快的使用Jinja2啦~