模板路径
# 模板设置
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'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',
],
},
},
]
模板查找顺序:优先在DIRS设置的目录下查找templates,如果没有并且 'APP_DIRS': True时,继续在注册的app文件下查找templates。
app注册后才能查找内部模板
#app注册
INSTALLED_APPS = [
'teacher', # 注册teacherAPP
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
]
模板变量
模板变量命名:同变量命名规则,且不能以下划线(_)开头
def test(request):
# tp = get_template('teacher/index.html')
# html = tp.render()
# return HttpResponse(html)
def num():
a = 1 + 2 + 3
return a
time = datetime.now()
li = [1,2,3]
dic = {'name': 'haha', 'age': 18}
tup = (1,2,3)
return render(request, 'teacher/index.html',context={
'li': li,
'time': time,
'num': num,
'dic': dic,
'tup': tup,
})
html文件:
<body>
<p>变量a:{{ time }}</p>
<p>列表li:{{ li }}</p>
<p>列表中的值:{{ li.2 }}</p>
<p>函数num:{{ num }}</p>
<!--调用函数时,函数不能带参数-->
<!--调用函数、表达式时,会直接返回结果-->
<p>字典:{{ dic }},字典中的值:{{ dic.name }}</p>
<p>字典方法:{{ dic.keys }}</p>
<!--当属性/方法名与键名冲突时,优先调用键名-->
<p>元组:{{ tup }},值:{{ tup.1 }}</p>
</body>
<!--调用渲染失败是会返回空字符' '-->
运行结果:
变量time:Feb. 19, 2019, 3:17 p.m.
列表li:[1, 2, 3]
列表中的值:3
函数num:6
字典:{'name': 'haha', 'age': 18},字典中的值:haha
字典方法:dict_keys(['name', 'age'])
元组:(1, 2, 3),值:2
过滤器filter
常用模板过滤器 add 将参数与值相加 首先尝试转换成整数相加,失败,则尝试所有可能,字符串,列表等。 {{ value|add:"2" }}
capfirst 首字母大写,如果第一个字母不是字母则不起作用。 {{ value|capfirst }}
date 日期格式化 {{ value|date:"D d M Y" }} time 时间格式化 {{ value|time:"H:i" }} 格式化格式见官方文档: https://docs.djangoproject.com/en/2.1/ref/templates/builtins/#date
default 如果变量解析失败,使用给定的默认值。 {{ value|default:"nothing" }}(注意如果value是''空字符串,输出将会是'nothing')
first 返回列表的第一个元素 {{ value|first }}
last 返回列表的最有一个元素 {{ value|last }}
slice 返回一个列表的切片 {{ some_list|slice:":2" }}
join 连接字符串列表 与str.join(list)一样 {{ value|join:" // " }}
floatformat 浮点数格式化 不指定小数位参数,默认保留一个为小数 (四舍五入)
length 返回字符串或列表的长度
length_is 判断字符串或列表长度是否指定的值,相等返回True {{ value|length_is:"4" }}
lower 字符串中的字母都变小写{{ value|lower }}
upper 字符串中的字母都变大写{{ value|upper }}
safe 关闭变量的自动转义,使html标签生效{{ value|safe }}
title 标题化,首字母大写 {{ value|title }}
{#模板变量#}
<p>变量time:{{ time }}</p>
<p>列表li:{{ li }}</p>
<p>列表中的值:{{ li.2 }}</p>
<p>函数num:{{ num }}</p>
<p>字典:{{ dic }},字典中的值:{{ dic.name }}</p>
<p>字典方法:{{ dic.keys }}</p>
<p>元组:{{ tup }},值:{{ tup.1 }}</p>
{#过滤器#}
<p>add:a+b={{ a|add:b }}</p>
<p>capfirst:{{ li.3|capfirst }}</p>
<p>data:{{ time|date:'Y-m-d H:i:s' }}</p>
<P>default:{{ hhh|default:'nothing' }}</P>
<p>first:{{ li|first }}</p>
<p>last:{{ li|last }}</p>
<p>slice:{{ li|slice:'::-1' }}</p>
<p>join:{{ li|join:'00' }}</p>
<p>floatformat:{{ 3.1415926|floatformat:3 }}</p>
<p>length is 4:{{ li|length_is:4 }}</p>
<p>upper:{{ li.3|upper }}</p>
<p>title:{{ 'this is a test'|title}}</p>
<p>safe:{{ '<h1>666<h1>'|safe }}</p>
静态文件引入
(css,js,图片文件)
路径配置:settings文件中
# 引入文件时使用的目录
STATIC_URL = '/my_static/'
# 静态文件的真实目录
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]
1、硬编码:
<link rel="stylesheet" href="/my_static/teacher/index.css">
2、模板标签:(推荐)
<!--加载static-->
{% load static %}
<link rel="stylesheet" href="{% static 'teacher/css/index.css' %}">