模板语法之过滤器(类似于内置函数) 模板语法之标签 自定义过滤器、标签、inclusion_tag 模板的导入 模板的继承 前期数据准备
day54
模板语法之过滤器(类似于内置函数)
使用的时候可以参考源码
1.语法结构
{{ 数据对象|过滤器名称:参数 }} 过滤器最多只能额外传输一个参数
代码演示:
url(r'^index/', views.index),
def index(request): s1 = 'hello jason 周一综合征可不能犯啊' return render(request, 'index.html', locals()) # 返回数据的长度 无法统计的话 会返回0
<p>{{ s1|length }}</p>
2.常见过滤器(django模板语法提供了60+过滤器 我们了解几个即可)
<p>统计数据的长度:{{ s1|length }}</p> <p>算术加法或者字符串加法:{{ n1|add:111 }}、{{ s1|add:'big baby' }}</p> <p>将数字转成合适的文件计量单位:{{ file_size|filesizeformat }}、{{ file_size1|filesizeformat }}</p> # 返回KB\MB计量单位 <p>判断当前数据对象对应的布尔值是否是False:{{ b|default:'前面的值对应的布尔值是False' }}、{{ s1|default:'前面的值对应的布尔值是False' }}</p> <p>时间格式化:{{ ctime|date:'Y-m-d' }}</p> <p>索引切片:{{ s1|slice:'0:8' }}</p> <p>按照空格截取指定个数的文本:{{ s2|truncatewords:5 }}、{{ s1|truncatewords:1 }}</p> # 数字5表示截取5次 文本后面用...结尾 <p>按照字符个数截取文本(包含三个点):{{ s2|truncatechars:5 }}、{{ s1|truncatechars:10 }}</p> # 数字5表示截取2个字符加上...共五个字符 <p>移除指定的字符:{{ info|cut:'|' }}</p> # cut(移除) <p>是否取消转换:{{ tag1 }}、{{ tag1|safe }}、{{ scripts1|safe }}、{{ res }}</p>
过滤器重点
代码演示:
def index(request): tag1 = '<h1>我是一个标题标签</h1>' return render(request, 'index.html', locals())
传到html
<p>:{{ tag1 }}</p>
显示出来的:<h1>我是一个标题标签</h1>
这是因为django和浏览器交互的时候 默认你所传的那些标签的数据不安全
我的本意是希望浏览器帮我渲染成标签
如果你想要渲染的话 必须主动告诉它 这个标签是安全的 需要这样写:
<p>{{ tag1 }}、{{ tag1|safe }}</p>
|safe
可以前端做 也可以在后端做 如果在后端操作需要导一个模块
from django.utils.safestring import mark_safe
view
ttt = '<a href=https://www.baidu.com>点我</a>' res = mark_safe(ttt)
html
<p>{{ res }}</p>
ps:最后一个|safe启发了我们以后用django开发全栈项目前端页面代码(主要指HTML代码)也可以在后端编写
模板语法之标签
# 在django模板语法中写标签的时候 只需要写关键字然后tab键就会自动补全
1.语法结构 {% 名字 ...%} {% end名字 %} 2.if判断 {% if 条件1 %} # 必须要引用变量 <p>你好啊</p> {% elif 条件2 %} <p>他好呀</p> {% else %} <p>大家好</p> {% endif %} 3.for循环 提供了forloop关键字 {'parentloop': {}, 'counter0': 0, 'counter': 1, 'revcounter': 4, 'revcounter0': 3, 'first': True, 'last': False} first:标识当前这次循环是不是第一次循环 last: 标识这次循环是不是第一次循环 counter0:从0开始计数 counter:从1开始计数 revcounter:从1开始计数 revcounter0:从0开始计数 # 常规for循环 {% for i in l1 %} <p>{{ i }}</p> {% endfor %} for+if嵌套使用 {% for i in l1 %} {% if forloop.first %} <p>这是第一次循环</p> {% elif forloop.last %} <p>这是最后一次循环</p> {% else %} <p>中间循环</p> {% endif %} {% empty %} <p>for循环对象为空 自动执行</p> {% endfor %}
# 针对字典同样提供了keys、values、items方法
view
user_info = {'name':'jason','pwd':123,'hobby':'read'} return render(request, 'index.html', locals())
html
{% for foo in user_info %} {{ foo }} # name pwd hobby {% endfor %} {% for foo in user_info.keys %} {{ foo }} # name pwd hobby {% endfor %} {% for foo in user_info.values %} {{ foo }} # jason 123 read {% endfor %} {% for foo in user_info.items %} {{ foo }} # ('name','jason')('pwd',123)('hobby','read')
自定义过滤器、标签、inclusion_tag
# 自定义过滤器前期准备:
1.在应用下需要创建一个名为templatetags的文件夹
2.在该文件夹内创建一个任意名称的py文件
3.在该py文件内需要先提前编写两行固定的代码
from django import template
register = template.Library()
# 自定义过滤器:只能接收两个参数
view
@register.filter(is_safe=True) def index(a, b): return a + b
html
{% load mytag %} # 加载过滤器 {{ n1|index:666 }}
# 自定义简单标签:可以接收任意的参数
view
@register.simple_tag(name='my_tag') def func1(a, b, c, d): return a + b + c + d
html
{% my_tag 1 2 3 4 %} # 参数之间空格隔开即可
# 自定义inclusion_tag
view
@register.inclusion_tag('left.html') def func2(n): l1 = [] for i in range(1, n + 1): l1.append(f'第{i}页') return locals()
left.html (将自带的内容全部删除 在空页面内编写代码)
<ul> {% for foo in l1 %} <li>{{ foo }}</li> {% endfor %} </ul>
html
{% func2 10 %}
该方法需要先作用于一个局部html页面 之后将渲染的结果放到调用的位置 相当于在该页面上封装了一个可以产生html代码的方法 那么这个html上的代码就变成了动态的 可以用来产生没有固定位数的p标签
模板的导入(了解)
类似于将html页面上的局部页面做成模块的形式 哪个地方想要直接导入即可展示
eg:
有一个非常好看的获取用户数据的页面 需要在网站的多个页面上使用
策略1:拷贝多份即可
策略2:模板的导入
使用方式
1. 写个局部htmlmenu.html
2. 在html中写到入代码
{% include 'menu.html' %}
注释语法补充
<!----> 是HTML的注释语法 {##} 是django模板语法的注释 HTML的注释可以在前端浏览器页面上直接查看到 模板语法的注释只能在后端查看 前端浏览器查看不了
模板的继承
类似于面向对象的继承:继承了某个页面就可以使用该页面上所有的资源
有很多网站的很多页面 其实都是差不多的 只是局部有所变化 模板的继承可以很好的实现该需求
1. 先在模板中通过block划定将来可以被修改的区域 把被修改的区域放进block中
home主页面
{% block content %} <h1>主页内容</h1> {% endblock %}
2.子板继承模板 进行修改 前提是先清空整个页面再进行编写
reg子页面
{% extends 'home.html' %} {% block content %} <h1>主页内容修改成登录内容</h1> {% endblock %}
3.子页面还可以重复使用父页面的内容
子页面
{{ block.super }}
# 模板上最少应该有三个区域
css区域、内容区域、js区域
子页面就可以有自己独立的css、js、内容
前期数据准备
django自带的sqlite3数据库 功能很少 并且针对日期类型不精确
所以使用mysql
1.数据库正向迁移命令(将类操作映射到表中)
python3 manage.py makemigrations
python3 manage.py migrate
2.数据库反向迁移命令(将表映射成类)
python3 manage.py inspectdb
我们只想操作orm 不想使用网络请求
需要有专门的测试环境
1.自己搭建
import os
if __name__ == __main__:
os.environ.setdefault(DJANGO_SETTINGS_MODULE, day54.settings)
import django
django.setup()
2.pycharm提供
python console