慕课网-Django入门到进阶-更适合Python小白的系统课程-第3章Django中的Template模板-3-7jinja2配置与使用方法
第3章 Django中的Template模板
3-7 jinja2配置与使用方法
1.创建项目
django-admin startproject jinja pip install jinja2 cd jinja python manage.py startapp app
2.在项目下目录 app,新建文件 base_jinja2.py
#!/usr/bin/env python
# -*- coding:utf-8 -*-
from jinja2 import Environment
from django.contrib.staticfiles.storage import staticfiles_storage
from django.urls import reverse
def environment(**options):
env = Environment(**options)
env.globals.update({
'static':staticfiles_storage.url,
'url':reverse
})
return env
3.在项目下目录 jinja,修改文件 settings.py,添加 jinja2 模板
#添加应用
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app',
]
#添加 jinja2 模板 和 虚拟环境
TEMPLATES = [
{
'BACKEND': 'django.template.backends.jinja2.Jinja2',
'DIRS': [os.path.join(BASE_DIR, 'templates')],
'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',
],
'environment':'app.base_jinja2.environment'
},
},
]
#添加静态文件路径
STATIC_URL = '/static/'
STATICFILES_DIRS = (os.path.join(BASE_DIR,'static'),)
4.在项目下添加目录 templates 和 static
5.在项目下目录 app,修改 views.py
from django.shortcuts import render
# Create your views here.
def test(request):
return render(request, 'test.html')
6.在项目下目录 templates,新建文件 test.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>hello django jinja2</h1>
</body>
</html>
7.在项目下目录 jinja,修改文件 urls.py
from django.contrib import admin
from django.urls import path
from app.views import test
urlpatterns = [
path('admin/', admin.site.urls),
path('test/', test)
]
8.测试

9.在项目下目录 app,修改 views.py
from django.shortcuts import render
# Create your views here.
def test(request):
data = {'name':'dewei', 'age':18}
return render(request, 'test.html', data)
10.在项目下目录 templates,新建文件 base.html
<!DOCTYPE html>
<html lang="en">
<head>
{% block head %}
<meta charset="UTF-8">
<title>{% block title %}{% endblock %}</title>
{% block css_style %}
{% endblock %}
{% endblock %}
</head>
<body>
{% block content %}
{% endblock %}
{% block js_script %}
{% endblock %}
</body>
</html>
11.在项目下目录 templates,修改文件 test.html
{% extends 'base.html' %}
{% block content %}
{{name|title}},{{age}}
{% endblock %}
12.测试

13.在项目下目录 app,添加文件 myfilter.py,自定义过滤器函数
#!/usr/bin/env python
# -*- coding:utf-8 -*-
def test(value, args):
return value * args
14.在项目下目录 app,修改文件 base_jinja2.py
#!/usr/bin/env python
# -*- coding:utf-8 -*-
from jinja2 import Environment
from django.contrib.staticfiles.storage import staticfiles_storage
from django.urls import reverse
from .myfilter import test
def environment(**options):
env = Environment(**options)
env.globals.update({
'static':staticfiles_storage.url,
'url':reverse
})
env.filters['test'] = test
return env
15.在项目下目录 templates,修改文件 test.html
{% extends 'base.html' %}
{% block content %}
{{name|title}},{{age|test(2)}}
{% endblock %}
16.测试

17.在项目下目录 static,添加文件 test.css,导入静态文件
* {
background-color: red;
}
18.在项目下目录 templates,修改文件 test.html
{% extends 'base.html' %}
{% block css_style %}
<link rel="stylesheet" href="/static/test.css" />
{% endblock %}
{% block content %}
{{name|title}},{{age|test(2)}}
{% endblock %}
19.测试

posted on 2020-01-20 05:33 herisson_pan 阅读(9) 评论(0) 收藏 举报
浙公网安备 33010602011771号