python框架之Django(3)-模版
常用语法
符号
{{...}} # 变量相关
{%...%} # 逻辑相关
{#...#} # 注释
使用变量
def test(request):
name = '张三'
age = 19
return render(request,'test.html',{'name':name,'age':19})
/[app name]/views.py
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>模板测试</title>
</head>
<body>
name:{{ name }} age:{{ age }}
</body>
</html>
/templates/test.html
result
for循环
def test(request):
name_list = ['张三', '李四', '王五']
return render(request, 'test.html', {'list': name_list})
/[app name]/views.py
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>模板测试</title>
</head>
<body>
{{ list }}
<hr>
{% for name in list %}
{{ name }}
{% endfor %}
</body>
</html>
/templates/test.html

result
使用字典
def test(request):
name_dict = {'firstname': 'zhang', 'lastname': 'san'}
return render(request, 'test.html', {'dict': name_dict})
/[app name]/views.py
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>模板测试</title>
</head>
<body>
{{ dict.firstname }}
{{ dict.lastname }}
</body>
</html>
/templates/test.html

result
使用对象
class Person:
def __init__(self,firstname,lastname):
self.firstname = firstname
self.lastname = lastname def show(self):
return 'my firstname is {},last name is {}'.format(self.firstname,self.lastname) def __str__(self):
return 'person obj name is {} {}'.format(self.firstname,self.lastname) def test(request):
p = Person('zhang','san')
return render(request, 'test.html', {'person': p})
/[app name]/views.py
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>模板测试</title>
</head>
<body>
{{ person.firstname }}
{{ person.lastname }}
<hr>
{{ person.show }}
<hr>
{{ person }}
</body>
</html>
/templates/test.html

result
Filters
语法: {{value|filter_name:params}}
default
当所修饰的变量为空时使用所指定的默认值
def test(request):
v1= None
v2 = '有值'
return render(request, 'test.html', {'v1': v1,'v2':v2})
/[app name]/views.py
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>模板测试</title>
</head>
<body>
{{ v1|default:'空值' }}
<hr>
{{ v2|default:'空值' }}
</body>
</html>
/templates/test.html

result
filesizeformat
文件大小格式化
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>模板测试</title>
</head>
<body>
{{ 123456789|filesizeformat }}
</body>
</html>
/templates/test.html

result
slice
切片
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>模板测试</title>
</head>
<body>
{{ 'abcdefghijklmn'|slice:'::2'}}
</body>
</html>
/templates/test.html

result
date
时间格式化
def test1(request):
from datetime import datetime
now = datetime.now()
return render(request, 'test.html', {'now': now})
/[app name]/views.py
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>模板测试</title>
</head>
<body>
{{ now }}
<hr>
{{ now|date:'Y-m-d H:i:s'}}
</body>
</html>
/templates/test.html

result
safe
不转义输出
def test(request):
a_tag = '<a href="http://www.baidu.com">超链接<a>'
return render(request, 'test.html', {'a_tag': a_tag})
/[app name]/views.py
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>模板测试</title>
</head>
<body>
{{ a_tag }}
<hr>
{{ a_tag|safe }}
</body>
</html>
/templates/test.html

result
truncatechars
显示指定长度字符,多余部分用'...'代替
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>模板测试</title>
</head>
<body>
{{ 'abcdefghijklmnopqrstuvwxyz'|truncatechars:10 }}
</body>
</html>
/templates/test.html

result
自定义filter
from django import template register = template.Library() @register.filter(name='append')
def add_sb(self, param1):
return '{}{}'.format(self, param1)
/[app name]/templatetags/myfilter.py
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>模板测试</title>
</head>
<body>
{% load myfilter %}
{{ '张三'| sb }}
</body>
</html>
/templates/test.html

result
Tags
自定义simpletag
from django import template register = template.Library() @register.simple_tag(name='add_str3')
def my_sum(str1, str2, str3):
return '{}{}{}'.format(str1, str2, str3)
/[app name]/templatetags/mytag.py
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>test</title>
</head>
<body>
{% load mytag %} {% add_str3 'a' 'b' 'c' %}
</body>
</html>
/templates/test.html

result
inclusion_tag
from django import template register = template.Library() @register.inclusion_tag('show_info_page.html')
def show_info(index):
list = [('张三', '男'), ('李四', '女')]
return {'person': list[index]}
/[app name]/templatetags/mytag.py
<h3>我的名字叫{{ person.0 }}</h3>
<p>性别{{ person.1 }}</p>
/[templates]/show_info_page.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>test</title>
</head>
<body>
{% load mytag %}
{% show_info 1 %}
<hr>
{% show_info 0 %}
</body>
</html>
/templates/test.html

result
母版页
block
在母版页中定义一个块让子页面使用
{% block [block name] %}
{% endblock %}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
这是母版页的内容
<hr>
{# 定义一个block块让子页面替换 #}
{% block page-main %} {% endblock %}
</body>
</html>
/[templates]/base.html
extends
继承母版页
{% extends '[母版页地址]' %}
{% block [block name] %}
{% endblock %}
{% extends 'base.html' %}
{%block page-main %}
这里是子页面的内容
{%endblock %}
/[templates]/test.html
扩展
forloop的属性
Variable | Description |
---|---|
forloop.counter |
当前循环的索引值(从1开始) |
forloop.counter0 |
当前循环的索引值(从0开始) |
forloop.revcounter |
当前循环的倒序索引值(从1开始) |
forloop.revcounter0 |
当前循环的倒序索引值(从0开始) |
forloop.first |
当前循环是不是第一次循环(布尔值) |
forloop.last |
当前循环是不是最后一次循环(布尔值) |
forloop.parentloop |
本层循环的外层循环 |
for...empty
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>模板测试</title>
</head>
<body>
{% for i in list %}
有值则遍历
{% empty %}
空空如也
{% endfor %}
</body>
</html>
with
定义一个中间变量
{% with total=list.count %}
{{ total }}
{% endwith %}
include
引入指定页
{% include '[页面地址]' %}
<p>in subpage.html</p>
/templates/subpage.html
{% include 'subpage.html' %}
<hr>
in test.html
/templates/test.html
static&get_static_prefix
动态获取静态文件夹别名来拼接静态文件的url
配置如下
STATIC_URL = '/static/' STATICFILES_DIRS = [
os.path.join(BASE_DIR, "static1"),
os.path.join(BASE_DIR, "static2"),
]
要访问项目根目录下文件夹static1里的jquery.min.js文件,原来的写法是:
<script src='/static/jquery.min.js'></script>
使用static的写法是:
<script src="{% static 'jquery.min.js'%}"></script>
使用get_static_prefix的写法是:
<script src='{% get_static_prefix %}jquery.min.js'></script>
也可给路径起一个别名:
<script src="{% static 'jquery.min.js' as jquery_path %}"></script>
<!-- 之后就可以通过别名引入 -->
<script src="{{ jquery_path }}"></script>
python框架之Django(3)-模版的更多相关文章
- python框架之django
python框架之django 本节内容 web框架 mvc和mtv模式 django流程和命令 django URL django views django temple django models ...
- 第六篇:web之python框架之django
python框架之django python框架之django 本节内容 web框架 mvc和mtv模式 django流程和命令 django URL django views django te ...
- Python框架之Django学习
当前标签: Django Python框架之Django学习笔记(十四) 尛鱼 2014-10-12 13:55 阅读:173 评论:0 Python框架之Django学习笔记(十三) 尛 ...
- Python框架之Django的相册组件
Python框架之Django的相册组件 恩,没错,又是Django,虽然学习笔记已经结贴,但是学习笔记里都是基础的,Django的东西不管怎么说还是很多的,要学习的东西自然不会仅仅用十几篇博文就能学 ...
- Python框架之Django学习笔记(十一)
话说上次说到数据库的基本访问,而数据库我们主要进行的操作就是CRUD,也即是做计算处理时的增加(Create).读取(Retrieve)(重新得到数据).更新(Update)和删除(Delete),俗 ...
- Python高级进阶(二)Python框架之Django写图书管理系统(LMS)
正式写项目准备前的工作 Django是一个Web框架,我们使用它就是因为它能够把前后端解耦合而且能够与数据库建立ORM,这样,一个Python开发工程师只需要干自己开发的事情就可以了,而在使用之前就我 ...
- Python框架之Django学习笔记(十二)
Django站点管理 十一转眼结束,说好的充电没能顺利开展,反而悠闲的看了电视剧以及去影院看了新上映的<心花路放>.<亲爱的>以及<黄金时代>,说好的劳逸结合现在回 ...
- Python框架之Django学习笔记(十)
又是一周周末,如约学习Django框架.在上一次,介绍了MVC开发模式以及Django自己的MVT开发模式,此次,就从数据处理层Model谈起. 数据库配置 首先,我们需要做些初始配置:我们需要告诉D ...
- Python框架之Django学习笔记(九)
模型 之前,我们用 Django 建造网站的基本途径: 建立视图和 URLConf . 正如我们所阐述的,视图负责处理一些主观逻辑,然后返回响应结果. 作为例子之一,我们的主观逻辑是要计算当前的日期和 ...
随机推荐
- mybatis查询结果和接收的不一样
记一次大坑:mybatis查询结果和接收的不一样,折腾我好几个小时. 先上代码:代码是要查询排名,sql执行的结果 SELECT b.operator_id, b.class_count, b.cla ...
- Js 跳出两级循环的方法
做过一个复杂的验证方法,需要两层each验证之后反正报错的信息.因为双重循环的问题,纠结了很久. /** * 验证input 的值 是否输入 flg:验证成功 false:验证失败 */ functi ...
- nginx+lua的基本原理概念介绍
一. 概述 Nginx是一个高性能,支持高并发的,轻量级的web服务器.目前,Apache依然web服务器中的老大,但是在全球前1000大的web服务器中,Nginx的份额为22.4%.Nginx采用 ...
- Linux常用的基础组件
Linux服务器(新机器) yum install gcc gcc-c++ glibc-devel make ncurses-devel openssl-devel autoconf git yum ...
- C++ 非常量引用无效
/* 非常量引用无效 */ #include <iostream> using namespace std; /* C++标准的规定:非常量的引用不能指向临时对象: 为了防止给常量或临时变 ...
- 【分享】Vue 资源典藏(UI组件、开发框架、服务端、辅助工具、应用实例、Demo示例)
Vue 资源典藏,包括:UI组件 开发框架 服务端 辅助工具 应用实例 Demo示例 element ★11612 - 饿了么出品的Vue2的web UI工具套件 Vux ★7503 - 基于Vue和 ...
- 通过Application配置全局的Context
我本来配置了全局变量,但是使用SharedPreferences时总是报空指针异常,报错如下: FATAL EXCEPTION: main Process: com.XXX.xxx, PID: 192 ...
- AssetManager
AssetManager用于获取assets下的资源. 1.getassets()得到AssetManager 2.AssetManager.close() 关闭AssetManager 3.Reso ...
- 关于ping地址的几个意义
1.ping 127.0.0.1 判断电脑的tcp/ip协议栈有没有问题 2.ping 本机ip 判断电脑的网卡驱动有没有问题 3.ping 网关 判断数据是否可以到达路由 4.ping www.ba ...
- Abp之工作单元与事务
环境:Abp1.2 疑问:没有调用工作单元的SaveChanges方法引起的事务提交时机的问题. 例如:有一个应用服务代码如下: public void CreatePhrase(PhraseCrea ...