模板是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. Jetson TX2(2)ubutu1604--安装opencv3.4.0

    1安装OpenCV3.4.0+contrib 1 在终端中敲入以下两句sudo rm /var/cache/apt/archives/locksudo rm /var/lib/dpkg/lock su ...

  2. 【转】详解springboot-修改内置tomcat版本

    1.解析Spring Boot父级依赖 <parent> <groupId>org.springframework.boot</groupId> <artif ...

  3. PHP获取项目所有控制器方法名称

    PHP获取项目所有控制器方法名称 //获取模块下所有的控制器和方法写入到权限表 public function initperm() { $modules = array('admin'); //模块 ...

  4. wince单实例启动

    static class Program { [DllImport("Toolhelp.dll")] public static extern IntPtr CreateToolh ...

  5. Linux下用户和raid练习题

    1. 公司一开发人员申请对服务器10天的oldboy普通用户权限,如何操作? useradd oldboy passwd oldboy usermod -e `date -d "10day& ...

  6. 【zabbix教程系列】一、初识zabbix

    一.zabbix是什么? Zabbix是最终的企业级软件,专为实时监控从数以万计的服务器,虚拟机和网络设备收集的数百万个指标而设计. 二.zabbix能做什么? 监控任何事物,为任何类型的IT基础设备 ...

  7. codeforces444A

    DZY Loves Physics CodeForces - 444A DZY loves Physics, and he enjoys calculating density. Almost eve ...

  8. Spring MVC 使用介绍(十一)—— 跨域与静态资源访问

    一.跨域 服务端须在响应中添加相应响应头,从而允许跨域,具体可通过 public class CorsFilter extends OncePerRequestFilter { @Override p ...

  9. SQLServer 中多行数据合并成一行数据(一个字段)

    需求:有四行数据,如下: 1.苹果 2.橘子 3.桃子 4.波罗 合并成一个字段:苹果,橘子,桃子,波罗: 需求明确之后,先弄点测试数据,上代码: --创建一个临时表 Create table #te ...

  10. 2018ICPC青岛现场赛 重现训练

    先贴代码,以及简要题解. 和一个队友下午双排打了一下,队友光速签到,我签的J被嫌弃写得慢以及演员...然后我秒出了E了思路然而难以置信这么简单的思路当时才过了十几个,于是发现D.F不是太好做.最后交了 ...