一.MVC和MTV

  1. MVC

    M: Model : 数据库, 存取数据

    V: View: 视图, 信息的展示

    C: Controller: 控制器, 逻辑的控制, 负责调度, 传递指令

  2. MTV

    M: model: ORM操作

    T: Template: 模板, HTML

    V: View:  , 视图, 业务逻辑相关

二. 变量

  {{变量名}}

  由字母和下划线组成

  (.)

def template_test(request):l = [11, 22, 33]d = {"name": "alex"}class Person(object):def __init__(self, name, age):self.name = nameself.age = agedef dream(self):return "{} is dream...".format(self.name)Alex = Person(name="Alex", age=34)Egon = Person(name="Egon", age=9000)Eva_J = Person(name="Eva_J", age=18)person_list = [Alex, Egon, Eva_J]return render(request, "template_test.html", {"l": l, "d": d, "person_list": person_list})

view中代码

  模板中支持的写法

{# 取l中的第一个参数 #}
{{ l.0 }}
{# 取字典中key的值 #}
{{ d.name }}
{# 取对象的name属性 #}
{{ person_list.0.name }}
{# .操作只能调用不带参数的方法 #}
{{ person_list.0.dream }}

  注: 当模板系统遇到一个(.)时,会按照如下的顺序去查询:

  1. 在字典中查询

  2. 属性或者方法

  3. 数字索引

三. 过滤器 Filters

  过滤器用来修改变量的显示结果

  语法: {{value|filter_name:参数}}  参数最多一个  注意: '|' 左右没有空格没有空格

default  {{ value|default:"nothing"}}如果value值没传的话就显示nothing注:TEMPLATES的OPTIONS可以增加一个选项:string_if_invalid:'找不到',可以替代default的的作用。filesizeformat将值格式化为一个 “人类可读的” 文件尺寸 (例如 '13 KB', '4.1 MB', '102 bytes', 等等)。例如:{{ value|filesizeformat }}如果 value 是 123456789,输出将会是 117.7 MB。add给变量加参数{{ value|add:"2" }}value是数字4,则输出结果为6。{{ first|add:second }}如果first是 [1,.2,3] ,second是 [4,5,6] ,那输出结果是 [1,2,3,4,5,6] 。lower小写{{ value|lower }}upper大写{{ value|upper}}title标题{{ value|title }}ljust左对齐"{{ value|ljust:"10" }}"rjust右对齐"{{ value|rjust:"10" }}"center居中"{{ value|center:"15" }}"length{{ value|length }}返回value的长度,如 value=['a', 'b', 'c', 'd']的话,就显示4.slice  切片{{value|slice:"2:-1"}}first取第一个元素{{ value|first }}last取最后一个元素{{ value|last }}join使用字符串拼接列表。同python的str.join(list)。{{ value|join:" // " }}truncatechars如果字符串字符多于指定的字符数量,那么会被截断。截断的字符串将以可翻译的省略号序列(“...”)结尾。参数:截断的字符数{{ value|truncatechars:9}}date日期格式化{{ value|date:"Y-m-d H:i:s"}}可格式化输出的字符:点击查看。safeDjango的模板中会对HTML标签和JS等语法标签进行自动转义,原因显而易见,这样是为了安全。但是有的时候我们可能不希望这些HTML元素被转义,比如我们做一个内容管理系统,后台添加的文章中是经过修饰的,这些修饰可能是通过一个类似于FCKeditor编辑加注了HTML修饰符的文本,如果自动转义的话显示的就是保护HTML标签的源文件。为了在Django中关闭HTML的自动转义有两种方式,如果是一个单独的变量我们可以通过过滤器“|safe”的方式告诉Django这段代码是安全的不必转义。比如:value = "<a href='#'>点我</a>"

相关方法

  自定义filter -->  

    自定义过滤器只是带有一个或两个参数的Python函数:

  •   变量(输入)的值 - -不一定是一个字符串
  •   参数的值 - 这可以有一个默认值,或完全省略

    例如,在过滤器{{var | foo:“bar”}}中,过滤器foo将传递变量var和参数“bar”

    自定义filter代码文件摆放位置:

app01/__init__.pymodels.pytemplatetags/  # 在app01下面新建一个package package (py的一个包文件)__init__.pyapp01_filters.py  # 建一个存放自定义filter的py文件views.py

    编写自定义fifter

from django import template
register = template.Library()@register.filter
def fill(value, arg):return value.replace(" ", arg)@register.filter(name="addSB")
def add_sb(value):return "{} SB".format(value)

    使用自定义fifter

{# 先导入我们自定义filter那个文件 #}
{% load app01_filters %}{# 使用我们自定义的filter #}
{{ somevariable|fill:"__" }}
{{ d.name|addSB }}

四. Tags

 

for

<ul>
{% for user in user_list %}<li>{{ user.name }}</li>
{% endfor %}
</ul>

for循环可用的一些参数:

Variable Description
forloop.counter 当前循环的索引值(从1开始)
forloop.counter0 当前循环的索引值(从0开始)
forloop.revcounter 当前循环的倒序索引值(从1开始)
forloop.revcounter0 当前循环的倒序索引值(从0开始)
forloop.first 当前循环是不是第一次循环(布尔值)
forloop.last 当前循环是不是最后一次循环(布尔值)
forloop.parentloop 本层循环的外层循环

for ... empty

<ul>
{% for user in user_list %}<li>{{ user.name }}</li>
{% empty %}<li>空空如也</li>
{% endfor %}
</ul>

if,elif和else

  if: 1.不支持连续判断

     2. 不支持算数运算 + - * /

{% if user_list %}用户人数:{{ user_list|length }}
{% elif black_list %}黑名单数:{{ black_list|length }}
{% else %}没有用户
{% endif %}

当然也可以只有if和else

{% if user_list|length > 5 %}七座豪华SUV
{% else %}黄包车
{% endif %}

if语句支持 and 、or、==、>、<、!=、<=、>=、in、not in、is、is not判断。

with

定义一个中间变量

{% with total=business.employees.count %}{{ total }} employee{{ total|pluralize }}
{% endwith %} 

五. 继承

  母板: 提取多个页面的公共部分, 写到一个HTML页面中, 定义多个block块

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="x-ua-compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1"><title>Title</title>{% block page-css %}{% endblock %}
</head>
<body><h1>这是母板的标题</h1>{% block page-main %}{% endblock %}
<h1>母板底部内容</h1>
{% block page-js %}{% endblock %}
</body>
</html>

   继承模板

#在子页面中在页面最上方使用下面的语法来继承母板。
{% extends 'layouts.html' %}想修改的话可以通过模板设置的类名
{% block page-css %}
对应模板修改十五内容{% endblock %}

  块(block)

    通过在母板中使用{% block  xxx %}来定义"块"。

    在子页面中通过定义母板中的block名来对应替换母板中相应的内容。

{% block page-main %}<p>世情薄</p><p>人情恶</p><p>雨送黄昏花易落</p>
{% endblock %}

  组件

    一段不灵活的HTML代码段 nav.html

    可以将常用的页面内容如导航条,页尾信息等组件保存在单独的文件中,然后在需要使用的地方按如下语法导入即可。

使用下面代码调用
{% include 'navbar.html' %}

六. 静态文件相关 

{% load static %}
{% static  '静态文件相对路径' %}    ——》 获取到别名,跟后面的参数进行拼接
{% get_static_prefix %}  ——》 获取到别名

<link rel="stylesheet" href="{% get_static_prefix %}plugins/bootstrap-3.3.7/css/bootstrap.css">

  自定义inclusion_tag

    用于返回html代码片段

from django import templateregister = template.Library()@register.inclusion_tag('result.html')
def show_results(n):n = 1 if n < 1 else int(n)data = ["第{}项".format(i) for i in range(1, n+1)]return {"data": data}

templatetags/my_inclusion.py示例

<ul>{% for choice in data %}<li>{{ choice }}</li>{% endfor %}
</ul>

templates/result.html示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="x-ua-compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1"><title>inclusion_tag test</title>
</head>
<body>{% load my_inclusion %}{% show_results 10 %}
</body>
</html>

templates/index.html示例

七.其他

  1. csrf_token

  这个标签用于跨站请求伪造保护

  在页面的form表单里面写上{% csrf_token %} 否则 form的请求会被拒绝

  之前我们注释了

# 'django.middleware.csrf.CsrfViewMiddleware',现在可以打开了, 必须写上{% csrf_token %}

  2. 注释

    {#........................................#}

  3. 注意事项

    Django的模板语言不支持连续判断,即不支持以下写法:

{% if a > b > c %}
...
{% endif %}

     Django的模板语言中属性的优先级大于方法

def xx(request):d = {"a": 1, "b": 2, "c": 3, "items": "100"}return render(request, "xx.html", {"data": d})

    如上,我们在使用render方法渲染一个页面的时候,传的字典d有一个key是items并且还有默认的 d.items() 方法,此时在模板语言中:

{{ data.items }}

    默认会取d的items key的值。

转载于:https://www.cnblogs.com/Ryan-Yuan/p/11544665.html

Django - 模板相关相关推荐

  1. Python全栈:Django模板

    文章目录 1 模板引擎介绍和选择 2 Django模板相关配置 templates相关配置 3 模板变量的使用 渲染静态图片 渲染 Python中的对象 4 模板标签的使用 循环控制 条件控制 模板注 ...

  2. Django模板语言相关内容

    Django模板语言相关内容 Django模板系统 官方文档 常用语法 只需要记两种特殊符号: {{  }}和 {% %} 变量相关的用{{}},逻辑相关的用{%%}. 变量 在Django的模板语言 ...

  3. Django模板、配置文件、静态文件及案例实现(创建模板、设置模板查找路径、模板接收视图传入的数据、模板处理数据、BASE_DIR、DEBUG、本地语言与时区、App应用配置)

    1.Django模板 网站如何向客户端返回一个漂亮的页面呢? 漂亮的页面需要html.css.js. 可以把这一堆字段串全都写到视图中, 作为HttpResponse()的参数,响应给客户端. 存在的 ...

  4. django模板过滤器

    django模板&过滤器 声明:部分信息来源这篇博客https://www.cnblogs.com/maple-shaw/articles/9333821.html MVC: 模型(model ...

  5. Django—模板渲染

    参考文档: http://www.cnblogs.com/fnng/p/4373108.html https://code.ziqiangxuetang.com/django/django-intro ...

  6. Django模板语言(译)

    原文地址:https://docs.djangoproject.com/zh-hans/2.1/ref/templates/language/ 翻译日期:2019年3月8日-2019年3月9日 by: ...

  7. django模板系统(上)

    filters 过滤 default 替代作用 filesizeformat 格式化为人类可读 add 给变量加参数 lower 小写 upper 大写 title 标题 ljust 左对齐 rjus ...

  8. Django模板系统(非常详细)

    翻译www.djangobook.com之第四章:Django模板系统 The Django Book:第4章 Django模板系统 revised by xin_wang 前面的章节我们看到如何在视 ...

  9. Django 模板系统

    Django模板系统 常用语法 {{}} 变量相关 {%%} 逻辑相关 变量 格式 {{ 变量名 }} 命名规则 包括任何字母数字以及下划线 ("_")的组合 变量名称中不能有空格 ...

最新文章

  1. 何为OKR?为何使用OKR?
  2. python文件不存在时创建文件_python-创建一个文件(如果不存在)
  3. android 开发时遇到的各种问题1--Android双模(CDMA/GSM)手机短信相关
  4. AtomicInteger原子性
  5. [OS][FS]查看ext3文件系统分区的superblock
  6. Kafka 输入行太长 命令语法不正确
  7. request获得请求头
  8. 第九章 魔法方法、特性和迭代器
  9. 用JAVA制作小游戏——飞机大战(二)
  10. 五大成功企业家的成功创业箴言
  11. Flutter 是移动应用程序开发的未来?
  12. 设计模式之禅之设计模式-状态模式
  13. 双机流水作业调度问题——Johnson算法
  14. NB-IoT天线座和连接器SMA、U.FL、IPX、IPEX
  15. 第7周 项目6—停车场模拟
  16. iOS相机、相册的访问权限
  17. 华为ne20路由器登陆密码_很好的文章,主要是关于密码学和NE的基础知识
  18. 我叫MT online 公会BOSS百分比、难度、BOSS技能及站位
  19. android A~Z通讯录排序索引
  20. iPhone 中常用、好用的提醒类软件(闹钟、提醒事项、日历、滴答清单)

热门文章

  1. python 分位数计算代码_Python数据分析第十一节 数据运算
  2. 单链表的应用 就地逆置
  3. android 多个启动页,Android启动页的问题整理
  4. python高并发架构_python高并发的解决方案
  5. 微型计算机中存储器分成哪几个等级?它们各有什么特点?用途如何?,《微机原理》复习思考题第十二章存储器.DOC...
  6. java swing进度条_Java Swing创建自定义闪屏:在闪屏上添加Swing进度条控件(转)
  7. LeetCode 186. 翻转字符串里的单词 II
  8. LeetCode 95. 不同的二叉搜索树 II(递归)
  9. el表达式 循环_EL表达式和JSTL标签库(百战程序员047天)
  10. python2转python3代码_2to3 – 自动Python 2到3代码翻译 – 开发工具(Python教程)(参考资料)...