模板是html文档+Django逻辑语句的组合。

一、变量和标签

  变量通过{{ }}来表示,两个大括号中间是变量名。

  标签通过{% %}来表示,就是Python中的函数和方法。

  常用标签:

 {% for %} #表示遍历循环
 {% if %} #表示判断
 {% url "name" %} #表示路由地址
 {% load %} #加载相关文件
 {% csrf_token %} #用于防护跨站请求伪造攻击
 {% with %} #重新命名变量名
 {% extends %} #继承模板
 {% block %} #重写父类模板的代码

跨站请求伪造:

  可以写一个和正规网站一样的钓鱼网站,拿转账举例,这个网站把原来填写转入账户的input标签的name属性去掉,自己加一个name属性为自己账户的input,用户看不出来,这样实际把钱就骗到手了,所以引入了csrf,他网页请求时返回一个隐藏的带有随机字符串的input标签,在提交数据时验证这个字符串,如不一致则拒绝请求。

XSS攻击:

变量 描述
forloop.counter 获取当前循环的索引,从1开始
forloop.counter0 获取当前循环的索引,从0开始
forloop.revcounter 从最大数开始索引,依次递减,直到索引到1
forlopp.revcounter0 从最大数开始索引,依次递减,直到索引到0
forloop.first 当遍历第一个元素时为真
forloop.last 当遍历最后一个元素时为真
forloop.parentloop 获取上层for循环的索引

二、模板的继承

  在html中首行写{% extends “xxxx.html” %},则可以继承所有代码。

  在原文档中,可以用{% block name %} {% endblock %}将想要在子模板中重写的部分包裹起来,在子文档中重写。

三、自定义过滤器

  过滤器是对变量的内容进行处理,支持多个过滤器同时使用,但仅支持传入一个参数。

  {{ variable |  filter1 | filter2 }}

  也可以自定义过滤器,方法如下:

  1、在app中创建templatetags包,在其中创建任意名称的py文件。

  2、文件中代码:

 from django import template

 register = template.Library()

 @register.filter
 def MyFilter(x,y):
     return x+y

  3、在模板中使用,需在首行导入文件:{% load 文件名 %}

Django-3-Template模板的更多相关文章

  1. Python Django 之 Template 模板的使用

    一.模板样式 注意: 1.url urlpatterns = { path('admin/', admin.site.urls), path('order/', views.order), path( ...

  2. Python Django 之 Template 模板语言简介

    一.什么事模板语言 html+逻辑控制语句 二.模板语言的作用 帮助前端处理后端发来的数据,方便前端展示(杂糅渲染) 三.模板语言语法 1.{{变量}} 变量使用双大括号{{}} 2.万能的句点号. ...

  3. django基础2: 路由配置系统,URLconf的正则字符串参数,命名空间模式,View(视图),Request对象,Response对象,JsonResponse对象,Template模板系统

    Django基础二 request request这个参数1. 封装了所有跟请求相关的数据,是一个对象 2. 目前我们学过1. request.method GET,POST ...2. reques ...

  4. django template 模板

    九.Template模板 Template 模板是根据view传过来数据在html展示的功能,典型python 模板jinjia2库提供丰富的上下文展示func 创建template位置在项目下与ap ...

  5. python框架Django中MTV框架之Template(模板/界面)

    MTV框架之Template(模板/界面) 关注公众号"轻松学编程"了解更多. 1.模板目录位置 应用下 不需要注册 无法跨应用地进行复用 工程下 需要注册 settings.py ...

  6. python Django教程 之模板渲染、循环、条件判断、常用的标签、过滤器

    python3.5 manage.py runserver python Django教程 之模板渲染.循环.条件判断.常用的标签.过滤器 一.Django模板渲染模板 1. 创建一个 zqxt_tm ...

  7. Python Web框架篇:Django templates(模板)

    为什么用templates? views.py视图函数是用来写Python代码的,HTML可以被直接硬编码在views.py之中.如下: import datetime def current_tim ...

  8. Django框架简介-模板系统

    2.4 模板 官方文档 2.4.1 常用语法 只需要记两种特殊符号: {{  }}和 {% %} 变量相关的用{{}},逻辑相关的用{%%}. 2.4.1.1 变量 {{ 变量名 }} 变量名由字母数 ...

  9. Django之Template

    模板层(template) 概念:  模板与html的区别:  模板=html+模板语法 模板语法: 1 变量:       {{}}    深度查询: 通过句点符.    列表,字典    clas ...

  10. 3.Django| 视图层| 模板层

    1.视图函数 文件在view_demo 一个视图函数简称视图,是一个简单的Python 函数,它接受Web请求并且返回Web响应.响应可以是一张网页的HTML内容,一个重定向,一个404错误,一个XM ...

随机推荐

  1. sanic set up

    (venv) MacBook-Pro:bin shihw$ pip3 install sanicCollecting sanic Downloading https://files.pythonhos ...

  2. PHP利用多进程处理任务

    PHP多进程一般应用在PHP_CLI命令行中执行php脚本,不要在web访问时使用.   多进程处理分解任务一般要比单进程更快.   php查看是否安装多进程模块: php -m | grep pcn ...

  3. maven压缩js css

    maven压缩<plugin> <!-- YUI Compressor Maven压缩插件 --> <groupId>net.alchim31.maven</ ...

  4. 算法笔记-状压dp

    状压dp 就是把状态压缩的dp 这样还是一种暴力但相对于纯暴力还是优雅的多. 实际上dp就是经过优化的暴力罢了 首先要了解位运算 给个链接吧 [https://blog.csdn.net/u01337 ...

  5. Redhat6.4安装Oracle 11gr2 64位 注意事项

    安装步骤略, 安装步骤参考:https://www.cnblogs.com/jhlong/p/5442459.html 注意的是,会出现找不到一些依赖库,我根据光盘已有的库安装了所有64位的依赖库,强 ...

  6. es6可变参数-扩展运算符

    es5中参数不确定个数的情况下: //求参数和 function f(){ var a = Array.prototype.slice.call(arguments); var sum = 0; a. ...

  7. Yesterday when I was young

    Somehow, it seems the love I knew was always the most destructive kind 不知为何,我经历的爱情总是最具毁灭性的的那种 Yester ...

  8. wsgi和Django的middleware思维导图

  9. JAVA并发包学习

    1)CyclicBarrier一个同步辅助类,允许一组线程相互等待,直到这组线程都到达某个公共屏障点.该barrier在释放等待线程后可以重用,因此称为循环的barrier 2)CountDownLa ...

  10. Spring MVC 使用介绍(七)—— 注解式控制器(三):生产者与消费者模型

    一.MIME类型 MIME类型格式:type/subtype(;parameter)? type:主类型,任意的字符串,如text,如果是*号代表所有 subtype:子类型,任意的字符串,如html ...