Jinja2 模板在 Django 1.9 中不起作用
Jinja2 templating not working in in Django 1.9
根据 Django 1.9 tutorial 上的说明,我在项目根目录中使用环境设置添加了另一个文件 -
from __future__ import absolute_import # Python 2 only
from django.contrib.staticfiles.storage import staticfiles_storage
from django.core.urlresolvers import reverse
from jinja2 import Environment
def environment(**options):
env = Environment(**options)
env.globals.update({
'static': staticfiles_storage.url,
'url': reverse,
})
return env`
(允许加载正确的 jinja2
我不得不以不同的方式重命名文件,在本例中 jinja2env.py
在项目根目录中)
我用新的模板后端更新了 settings.py
:
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(PROJECT_ROOT, 'templates').replace('\','/')],
'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',
],
},
},
{
'BACKEND': "django.template.backends.jinja2.Jinja2",
'DIRS': [os.path.join(PROJECT_PATH, 'campaigns/templates').replace('\','/')],
"APP_DIRS": True,
"OPTIONS": {
'environment': 'jinja2env.Environment',
}
},
在我正在处理的视图中,我使用 using
参数来指定 jinja2
模板引擎:
return render(request, 'jinja2/index.html', context={'projects': projects, 'counter': 0}, status=200, using='jinja2')
然而,当模板开始渲染时,出现以下错误:'static' is undefined
。显然我的设置是错误的,或者我没有做正确的事情。模板是这样开始的:
<link rel="stylesheet" type="text/css" href="{{ static('stylesheets/main.css') }}">
我做错了什么?我不使用 {% load static %}
因为它不是 Django 模板...所以我很茫然。
根据您的设置和对 this question 的接受答案,看来您应该尝试添加 static
上下文处理器。
您载入了错误的环境。在您的代码中 jinja2env.Environment
实际上指的是 jinja2.Environment
.
中的默认环境
"OPTIONS": {
'environment': 'jinja2env.Environment',
}
应该改为
"OPTIONS": {
'environment': 'jinja2env.environment',
}
注意小写的 environment
,这是您在 jinja2env.py
.
中定义的环境
根据 Django 1.9 tutorial 上的说明,我在项目根目录中使用环境设置添加了另一个文件 -
from __future__ import absolute_import # Python 2 only
from django.contrib.staticfiles.storage import staticfiles_storage
from django.core.urlresolvers import reverse
from jinja2 import Environment
def environment(**options):
env = Environment(**options)
env.globals.update({
'static': staticfiles_storage.url,
'url': reverse,
})
return env`
(允许加载正确的 jinja2
我不得不以不同的方式重命名文件,在本例中 jinja2env.py
在项目根目录中)
我用新的模板后端更新了 settings.py
:
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(PROJECT_ROOT, 'templates').replace('\','/')],
'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',
],
},
},
{
'BACKEND': "django.template.backends.jinja2.Jinja2",
'DIRS': [os.path.join(PROJECT_PATH, 'campaigns/templates').replace('\','/')],
"APP_DIRS": True,
"OPTIONS": {
'environment': 'jinja2env.Environment',
}
},
在我正在处理的视图中,我使用 using
参数来指定 jinja2
模板引擎:
return render(request, 'jinja2/index.html', context={'projects': projects, 'counter': 0}, status=200, using='jinja2')
然而,当模板开始渲染时,出现以下错误:'static' is undefined
。显然我的设置是错误的,或者我没有做正确的事情。模板是这样开始的:
<link rel="stylesheet" type="text/css" href="{{ static('stylesheets/main.css') }}">
我做错了什么?我不使用 {% load static %}
因为它不是 Django 模板...所以我很茫然。
根据您的设置和对 this question 的接受答案,看来您应该尝试添加 static
上下文处理器。
您载入了错误的环境。在您的代码中 jinja2env.Environment
实际上指的是 jinja2.Environment
.
"OPTIONS": {
'environment': 'jinja2env.Environment',
}
应该改为
"OPTIONS": {
'environment': 'jinja2env.environment',
}
注意小写的 environment
,这是您在 jinja2env.py
.