Django模块
在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.html
hello.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',
],
},
},
]
...
Django模板标签
变量
模板语法
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/else标签
基本语法格式如下
{% 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标签
{% 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 %}
可选的{% empty %}从句:在循环为空的时候执行
{% for i in listvar %}
{{ forloop.counter0 }}
{% empty %}
空空如也~
{% endfor %}
ifequal/ifnotequal标签
{% 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 %}标签允许在模板中包含其他的模块的内容
{% include "nav.html" %}
csrf_token
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 * v2
5、利用装饰器@register.simple_tag自定义标签
@register.simple_tag
def my_tag1(v1, v2, v3):
return v1 * v2 * v3
6、在使用自定义标签和过滤器之前,要在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 "父模板路径"%}
子模版如果没有设置父模板预留区域的内容,则使用在父模板设置的默认内容,当然也可以都不设置,就为空。