在HelloWorld目录下创建templayes目录,并建立hello.html文件
HelloWorld/ |-- HelloWorld | |-- __init__.py | |-- __init__.pyc | |-- settings.py | |-- settings.pyc | |-- urls.py | |-- urls.pyc | |-- views.py | |-- views.pyc | |-- wsgi.py | `-- wsgi.pyc |-- manage.py `-- templates `-- hello.htmlhello.html文件代码
<h1>{{ hello }}</h1>模板中变量使用双括号
建好模板之后还需说明模板文件路径,修改HelloWorld/settings.py,修改中TEMPLATES中的DIRS。
...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', ], }, }, ] ...变量
模板语法
view:{"HTML变量名" : "views变量名"} HTML:{{变量名}}HelloWorld/HelloWorld/views/py文件
from django.shortcuts import render def runoob(request): views_name = "world" return render(request,"runoob.html", {"name":views_name})templates中的hello.html
<p>{{ name }}</p>templates中的hello.html中,可以用.索引下标取出对应的元素。
from django.shortcuts import render def runoob(request): views_list = ["wordl1","world2","world3"] return render(request, "hello.html", {"views_list": views_list})HelloWorld/templates/hello.html文件代码:
<p>{{ views_list }}</p> # 取出整个列表 <p>{{ views_list.0 }}</p> # 取出列表的第一个元素templates中的runoob.html中,可以用.键取出对应的值
from django.shortcuts import render def runoob(request): views_dict = {"name":"world"} return render(request, "runoob.html", {"views_dict": views_dict})HelloWorld/templayes/hello.html文件代码
<p>{{ views_dict }}</p> <p>{{ views_dict.name }}</p>模板语法
{{ 变量名 | 过滤器:可选参数 }}模板过滤器可以在变量被显示前修改它,过滤器使用管道字符
{{ name|lower }}{{ name }}变量被过滤器lower处理后,文档大写转换文本为小写。
过滤管道可以被“套接”,即是说,一个过滤器管道的输出又可以作为下一个管道的输入
# 将第一个元素转换为大写 {{ my_list|first|upper }}其他过滤器
addslashes:添加反斜杠到任何反斜杠、单引号或者双引号前面date:按指定的格式字符串参数格式化date或者datetime对象 {{ pub_date|date:"F j, Y" }}length:返回变量的长度
default default为变量提供一个默认值
如果views传的变量的布尔值是false,则使用指定的默认值
HelloWorld/HelloWorld/views.py文件代码
from django.shortcuts import render def runoob(request): name =0 return render(request, "hello.html", {"name": name})HelloWorld/templates/hello.html
{{ name|default:"world" }}filesizeformat 以更易读的方式显示文件的大小(即13KB,4.1MB等)
safe
将字符串标记为安全,不需要转义。
要保证views.py传过来的数据绝对安全,才能用safe。和后端views.py的mark_safe效果相同。
Django会自动对views.py传到HTML文件中的标签语法进行转义,令其语义失效。
加safe过滤器是告诉Django该数据是安全的,不必对器进行转义,可以让该数据语义生效。
HelloWorld/HelloWorld/views.py文件代码
from django.shortcuts import render def runoob(request): views_str = "<a href='https://www.baidu.com/'>点击跳转</a>" return render(request, "hello.html", {"views_str": views_str})HelloWorld/templates/hello.html
{{ views_str|safe }}基本语法格式如下
{% if condition %} ... display {% endif %}或者
{% if condition1 %} ... display 1 {% elif condition2 %} ... display 2 {% else %} ... display 3 {% endif %}根据条件判读是否输出,支持嵌套
HelloWorld/HelloWorld/views.py文件代码
from django.shortcuts import render def runoob(request): views_num = 88 return render(request, "hello.html", {"num": views_num})HelloWorld/templates/hello.html
{%if num > 90 and num <= 100 %} 优秀 {% elif num > 60 and num <= 90 %} 合格 {% else %} 一边玩去~ {% endif %}{% for %}允许在一个序列上迭代
与Python的for语句的情形类似。
每一次循环中,模块系统会渲染在{% for %}和{% endfor %}之间的所有内容。
{% for i in views_list %} {{ i }} {% endfor %}遍历字典可以直接用字典**.items**方法,用变量的解包分别获取键和值。
{% for i,j in views_dict.items %} {{ i }}---{{ j }} {% endfor %}在{% for %}标签里可以通过{{ forloop }}变量获取循环序号。
forloop.counter 顺序获取循环序号,从1开始计算forloop.counter() 顺序获取循环序号,从0开始计算 {% for i in listvar %} {{ forloop.counter }} # 顺序获取循环序号,从 1 开始计算 {{ forloop.counter0 }} # 顺序获取循环序号,从 0 开始计算 {{ forloop.revcounter }} #倒叙获取循环序号,结尾序号为 1 {{ forloop.revcounter0 }} # 倒叙获取循环序号,结尾序号为 0 {{ forloop.first }} # 第一条数据返回 True,其他数据返回 False {{ forloop.last }} # 最后一条数据返回 True,其他数据返回 False {% endfor %}可选的{% empty %}从句:在循环为空的时候执行
{% for i in listvar %} {{ forloop.counter0 }} {% empty %} 空空如也~ {% endfor %}{% ifequal %}标签比较两个值,当它们相等时,显示在{% ifequal %}和{% endifequal %}之中所有的值。
{% ifequal user currentuser %} <h1>Welcome!</h1> {% endifequal %}和{% if %}类似,支持可选的{% else %}标签
{% ifequal section 'sitenews' %} <h1>Site News</h1> {% else %} <h1>No News Here</h1> {% endifequal %}注释使用{# #}
{# 这是一个注释 #}{% include %}标签允许在模板中包含其他的模块的内容
{% include "nav.html" %}csrf_token用于form表单中,作用是跨站请求伪造保护。
如果不用该标签,在用form表单时,跳转页面会报403权限错误。
1、在app目录下创建templatestags目录(目录名只能是templatestags)
2、在templatetags目录下创建任意py文件
3、在该py文件下
from django import template register = template.Library() # register的名字是固定的,不可改变4、利用装饰器@register.filter自定义过滤器
注:装饰器的参数最多只能有2个
@register.filter def my_filter(v1, v2): return v1 * v25、利用装饰器@register.simple_tag自定义标签
@register.simple_tag def my_tag1(v1, v2, v3): return v1 * v2 * v36、在使用自定义标签和过滤器之前,要在html文件body的最上方导入该.py文件
{% load my_tags %}7、在HTML中使用自定义过滤器
{{ 11|my_filter:22 }}8、在HTML中使用自定义标签
{% my_tag1 11 22 33 %}9、语义化标签
在该.py文件中导入mark_safe
from django.utils.safestring import mark_safe在定义标签是,用上mark_safe方法,令标签语义化,相当于jQuery中的html()方法。
和前端HTML文件中的过滤器safe效果一样。
@register.simple_tag def my_html(v1, v2): temp_html = "<input type='text' id='%s' class='%s' />" %(v1, v2) return mark_safe(temp_html)1、在项目根目录下创建statics目录
2、在settings文件的中配置添加以下配置
STATIC_URL = '/static/' # 别名 STATICFILES_DIRS = [ os.path.join(BASE_DIR, "statics"), ]3、在static目录下创建css目录,js目录,images目录,plugins目录,分别放css文件,js文件,图片,插件。
4、吧bootstrap框架放入插件目录plugins。
5、在HTML文件的head标签中引入bootstrap
注:此时引用路径中的要用配置文件中的别名static,而不是目录static。
在模板中使用需加入{% load static %}代码。
模板可以用继承的方式来实现复用,较少冗余内容
网页的头部和尾部内容一般都是一致的,就可以通过模板继承来实现复用。
父模板用于防止可重复利用的内容,子模版继承父模板的内容,并放置自己的内容。
父模板标签block…endblock(挖坑):父模板中的预留区域,该区域留给子模版填充差异性的内容,不同预留区域名字不能相同。
{% block 名称 %} 预留给子模板的区域,可以设置设置默认内容 {% endblock 名称 %} 子模版子模版使用标签extends继承父模板
{% extends "父模板路径"%}子模版如果没有设置父模板预留区域的内容,则使用在父模板设置的默认内容,当然也可以都不设置,就为空。
