模版语法

传值

视图函数向前端html页面传值,基本上所有的数据类型都可以渲染在前端页面上。

views.py

from django.shortcuts import render, redirect, HttpResponse

# Create your views here.

def index(request):
int_1 = 123
str_2 = '测试'
list_3 = [1, 2, 3]
dict_4 = {'a': 1, 'b': 2}
set_5 = {1, 2, 3, 4, 5}
tuple_6 = (1, 2, 3,)
float_7 = 3.1415926
bool_8 = True
return render(request, 'index.html', locals())

html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>index</title>
</head>
<body>
<p>{{ int_1 }}</p>
<p>{{ str_2 }}</p>
<p>{{ list_3 }}</p>
<p>{{ dict_4 }}</p>
<p>{{ set_5 }}</p>
<p>{{ tuple_6 }}</p>
<p>{{ float_7 }}</p>
<p>{{ bool_8 }}</p>
</body>
</html>

但是需要注意的是函数的渲染,如果在html页面渲染函数的话,不需要加括号就会会直接执行该函数,如果有返回值就会在页面显示返回值,没有返回值会显示None。类里面的函数也可以调用,但是也不要加括号,和flask模版语法不一样。

模版取值直接用点语法。

过滤器

模板过滤器可以在变量被显示前修改它,过滤器使用管道字符

{{ 变量名 | 过滤器:可选参数 }}

length

返回对象的长度,适用于字符串和列表。

字典返回的是键值对的数量,集合返回的是去重后的长度。

def index(request):
name = 'isable'
return render(request, 'index.html', locals())
{# html页面 #}
{{ name|length }} {# 输出长度结果 #}

date

根据给定格式对一个日期变量进行格式化。

格式 Y-m-d H:i:s返回 年-月-日 小时:分钟:秒 的格式时间。

import datetime
def index(request):
ctime = datetime.datetime.now()
print(ctime)
return render(request, 'index.html', locals())
{{ ctime|date:'Y-m-d H:i:s' }}

filesizeformat

以更易读的方式显示文件的大小(即'13 KB', '4.1 MB', '102 bytes'等)。

字典返回的是键值对的数量,集合返回的是去重后的长度。

def index(request):
file_size = 102900291913
return render(request, 'index.html', locals())
{{ file_size|filesizeformat }}

seaf

将字符串标记为安全,不需要转义。

要保证 views.py 传过来的数据绝对安全,才能用 safe。

和后端 views.py 的 mark_safe 效果相同。

为了防止XSS攻击,Django 会自动对 views.py 传到HTML文件中的标签语法进行转义,令其语义失效,在前端渲染成文本。加 safe 过滤器是告诉 Django 该数据是安全的,不必对其进行转义,可以让该数据语义生效。

from django.shortcuts import renderdef index(request):    views_str = "<script>alert(111)</script>"    return render(request, "index.html", {"views_str": views_str})
{{ views_str|safe }}

标签

for标签

与python中for循环语句类似每一次循环中,模板系统会渲染在 {% for %}{% endfor %} 之间的所有内容。

def index(request):	  l1 = [1, 2, 4, 5, 6]  return render(request, 'index.html', locals())
{% for foo in l1 %}    <p>{{ foo }}</p>{% endfor %}

在 {% for %} 标签里可以通过 {{forloop}} 变量获取循环序号。

  • forloop.counter: 顺序获取循环序号,从 1 开始计算
  • forloop.counter0: 顺序获取循环序号,从 0 开始计算
  • forloop.revcounter: 倒叙获取循环序号,结尾序号为 1
  • forloop.revcounter0: 倒叙获取循环序号,结尾序号为 0
  • forloop.first(一般配合if标签使用): 第一条数据返回 True,其他数据返回 False
  • forloop.last(一般配合if标签使用): 最后一条数据返回 True,其他数据返回 False

继承

模板可以用继承的方式来实现复用,减少冗余内容。

网页的头部和尾部内容一般都是一致的,我们就可以通过模板继承来实现复用。

父模板用于放置可重复利用的内容,子模板继承父模板的内容,并放置自己的内容。

# 父模板 给子模版需要更改的地方括起来 做标记{% block content_name %} 	# 需要更改的内容	{% endblock %}
# 子模板{% entends 'home.html' %}  #继承父模板内容{% block content_name %}	# 子模版内容{% endblock %}

Django测试环境的搭建

将manage.py文件里面的以下代码复制到app文件里面的tests.py:

import osimport sysif __name__ == "__main__":    os.environ.setdefault("DJANGO_SETTINGS_MODULE", "djangoProject02.settings")        import django    django.setup

需要注意的是 导入其他py文件的时候需要在django.setup()下面写。这时候就直接可以右键运行。

ORM单表中查询的方法

values

# 字段查询res = modes.User.objects.values('name', 'age')# 列表套字典

values_list

# 字段查询,与values用法一致# 返回值是列表套元组

去重

# 去重不要带主键字段,否则去重就没意义models.User.objects.values('name').distinct()

排序

res = model.User.object.values('name', 'age').order_by('-age')  # 默认是升序  给字段加上负号就是降序

reverse

res = modes.User.objects.order_by('age').reverse()# 倒序

count

# 统计出现次数res = models.User.objects.filter(name='egon').count()

Django 模版语法 测试环境 ORM单表查询的更多相关文章

  1. python 之 Django框架(orm单表查询、orm多表查询、聚合查询、分组查询、F查询、 Q查询、事务、Django ORM执行原生SQL)

    12.329 orm单表查询 import os if __name__ == '__main__': # 指定当前py脚本需要加载的Django项目配置信息 os.environ.setdefaul ...

  2. ORM单表查询,跨表查询,分组查询

    ORM单表查询,跨表查询,分组查询   单表查询之下划线 models.Tb1.objects.filter(id__lt=10, id__gt=1) # 获取id大于1 且 小于10的值models ...

  3. django之orm单表查询

    这几天重新学习了一下django的orm,以此作为记录来分享. Part1:修改配置,生成表 在写数据和查数据之前,首先先得把django配置一下,具体配置如下: 1.先在公共项目的settings中 ...

  4. 54 Django 模型层(1) 单表查询

    单表操作: 一 项目的操作顺序: 1 在model.py文件中创建表结构 class Book(models.Model): id=models.AutoField(primary_key=True) ...

  5. orm单表查询和模糊查询

    一.单表查询 1. 返回queryset对象的查询 all() 以列表形式返回全部queryset对象 filter(**kwargs) 筛选 exclude(**kwargs) 排除 reverse ...

  6. Django ORM单表查询必会13条

    必知必会13条 操作下面的操作之前,我们实现创建好了数据表,这里主要演示下面的操作,不再细讲创建准备过程 <1> all(): 查询所有结果 <2> filter(**kwar ...

  7. django框架基础-ORM单表操作-长期维护

    ###############    单表操作-添加数据    ################ import os if __name__ == '__main__': os.environ.set ...

  8. Django框架05 /orm单表操作

    Django框架05 /orm单表操作 目录 Django框架05 /orm单表操作 1. orm使用流程 2. orm字段 3. orm参数 4. orm单表简单增/删/改 5. orm单表查询 5 ...

  9. mysql(单表查询,多表查询,MySQl创建用户和授权,可视化工具Navicat的使用)

    单表查询 语法: 一.单表查询的语法 SELECT 字段1,字段2... FROM 表名 WHERE 条件 GROUP BY field HAVING 筛选 ORDER BY field LIMIT ...

随机推荐

  1. NetCore微服务简单流程审批数据库设计及后台服务开发

    1.数据库设计 -- ---------------------------- -- Table structure for TBase_Flow -- ----------------------- ...

  2. OpenResty简介

    OpenResty(也称为 ngx_openresty)是一个全功能的 Web 应用服务器.它打包了标准的 Nginx 核心,很多的常用的第三方模块,以及它们的大多数依赖项. 通过揉和众多设计良好的 ...

  3. asp网页防止乱码

    <%@LANGUAGE="VBSCRIPT" CODEPAGE="65001"%> <%Session.CodePage=65001%> ...

  4. asp.net 读取 connectionStrings

    connectionStrings 在vs.net 2005 beta 2开始,如果你在web.config中使用了数据库连接字符串的配置,那么应该按如下的方法去写: <connectionSt ...

  5. Python之手把手教你用JS逆向爬取网易云40万+评论并用stylecloud炫酷词云进行情感分析

    本文借鉴了@平胸小仙女的知乎回复 https://www.zhihu.com/question/36081767 写在前面: 文章有点长,操作有点复杂,需要代码的直接去文末即可.想要学习的需要有点耐心 ...

  6. ORM研究3 - odoo fields常用的字段属性

    之前我们已经讲解了odoo ORM中的一些对字段常用的API操作方法,今天我们继续研究一下Odoo orm中字段的一些通用属性字段的使用,学会它们可以为自己创建数据映射并使用有更好的帮助. 通用字段属 ...

  7. deepin解压乱码

    使用unzip命令解压:unzip -O GBK xxxx.zip -d xxx

  8. 微信小程序云开发-云函数-调用初始云函数获取openid

    一.调用初始云函数获取openid的两种方法 1.传统的success和fail 2.ES6的.then和.catch 3.编译结果 说明:初始云函数,是指刚创建完成的云函数.默认系统写的代码.

  9. C# 连接MySQL数据库 ,查询条件中有中文时,查询不出结果

    使用C#成功连接上MySql数据库后,但如果查询条件中有中文,查询结果就为空. String connetStr = "server=127.0.0.1;port=3306;user=roo ...

  10. Rowid和Rownum

    Rowid和Rownum对于数据库开发人员来说基本很少用到,因为在企业数据库开发中大多都是进行数据批处理,但是对于其他数据库人员来说还是会用到的. rowid和rownum都是虚列,但含义完全不同.r ...