django框架模板语言使用方法详解


Posted in Python onJuly 18, 2019

本文实例讲述了django框架模板语言使用方法。分享给大家供大家参考,具体如下:

模板功能

作用:生成html界面内容,模版致力于界面如何显示,而不是程序逻辑。模板不仅仅是一个html文件,还包括了页面中的模板语言。

  • 静态内容:css,js,html。
  • 动态内容:通过模板语言,动态生成一些网页内容

模板使用: 在视图函数中,使用模板产生html内容返回给客户端

方式一:

  1. 加载模板文件(loader.get_template)
  2. 模板渲染,产生标准的html页面内容(render)

通过HttpResponse对象,返回html界面内容给浏览器

def index(request):
  """进入首页"""
  context = {}  # 字典
  # 获取模板对象
  template = loader.get_template('index.html')
  # 渲染模板, 得到标准的html内容
  html_str = template.render(context, request)
  # 响应请求,返回html界面
  return HttpResponse(html_str)

方式二:

通过render()函数

def index(request):
  """进入首页"""
  context = {}  # 字典
  return render(request, 'index.html', context)

模板加载流程

Django会依次到以下目录查找模板文件,如果都找不到,则报错:

  1. 项目配置的模板目录
  2. admin应用的templates模板目录
  3. auth应用的templates模板目录

应用本身的templates模板目录

模板语言

DTL.(Django Template Language)简称: 模板语言

模板变量

格式: {{ 变量名 }}

模板变量名: 是由数字,字母,下划线组成,不能以下划线开头。

点(.) 也在会变量部分中出现, 点号(.)用来访问变量的属性。

当模版系统遇到点("."),它将以这样的顺序查询:

  • 字典查询(Dictionary lookup)
  • 属性或方法查询(Attribute or method lookup) (调用方法时不能传参)
  • 数字索引查询(Numeric index lookup)

如果模板变量不存在,则生成html内容时用 '' 空字符串代替。

例如: {{ book.btitle }}

1) 首先把book当成一个字典,把btitle当成键名,进行取值book['btitle']
2) 把book当成一个对象,把btitle当成属性或方法,进行取值

例如:{{ book.0 }}

1) 首先把book当成一个字典,把0当成键名,进行取值book['0']
2) 把book当成一个列表,把0当成下标,进行取值book[0]

模板标签

代码段

{% 代码段 %}

for 循环

遍历列表:

{% for x in 列表 %}
  列表不为空时执行
{% empty %}
  列表为空时执行
{% endfor %}

若加上关键字reversed则倒序遍历:

{% for x in 列表 reversed %}
{% endfor %}

遍历字典:

{% for key, value in my_dict.items %}
  {{ key }}: {{ value }}
{% endfor %}

可以通过 {{ forloop.counter }} 判断for循环执行到第几次,初始化值从1开始。

django框架模板语言使用方法详解

if 语句

{% if 条件 %}
{% elif 条件 %}
{% else %}
{% endif %}

关系比较操作符:

>    <     >=     <=     ==     !=

注意:进行比较操作时,比较操作符两边必须有空格。

逻辑运算:

not   and   or

过滤器

过滤器: 用于对模板变量进行操作,使用格式:

模板变量|过滤器:参数

一、内置过滤器

date: 改变日期的显示格式。

value|date:"Y年m月j日 H时i分s秒"

length: 求长度。字符串,列表,元组,字典长度

default: 设置模板变量的默认值。

data|default:'默认值'

二、自定义过滤器

需求: 实现两个自定义过滤器:

(1)判断是否奇偶
(2)求余操作

实现步骤:

  1. 创建包: 在应用下创建名字为templatetags的python包(名字固定)
  2. 创建模块: 在该templatetags下创建filters.py(名字随意取),该名字后面会使用到。

定义函数 自定义过滤器即带有一个或两个参数的python函数:

  • 参数1:模板变量
  • 参数2:参数,可选

装饰函数

  • 定义一个名字叫 register 的Library对象(名字固定)
  • 使用 @register.filter 对过滤器函数进行装饰

在模板界面中加载过滤器并使用: 在html中, 通过load标签导入自定义过滤器, 并使用:

模板注释

单行注释:

{# 注释内容 #}

多行注释:

{% comment %}
 注释内容
{% endcomment %}

模板继承

模板继承: 为了重用html页面内容

使用格式: {% extends 父模板文件路径 %}

块的使用:

在父模板里可以定义块:

{% block 块名 %}
  块中的内容(也可以没有)
{% endblock 块名%}

在子模板头部声明继承父模板:

{% extends 父模板文件路径 %}

示例:

{% extends "app01/parent.html" %}

在子模板中,重写父模板中的块(也可以不重写):

{% block 块名 %}
  {{ block.super}} #获取父模板中块的默认内容
  重写的内容
{% endblock 块名%}

Django中html转义

通过视图函数(render函数)传给模板的数据,如果含有特殊字符,默认是会转义的。

要关闭模板上下文字符串的转义:可以使用

{{ 模板变量|safe}}

也可以使用:

{% autoescape off %}
  模板语言代码
{% endautoescape %}

模板硬编码中的字符串默认不会转义,如果需要转义,那需要手动进行转义。

django框架模板语言使用方法详解

url反向解析

url逆向解析,反向解析

需求:当urls.py中的一个url配置项发生改变后,项目中所有硬编码引用该url链接的地方,都需要作修改。

解决方法:

给url配置项起个名字,在html界面中,再通过名字引用该url:

# project下的urls.py
urlpatterns = [
  ...
  url(r'^', include('app01.urls', namespace='应用名')),
]
# app01下的urls.py
urlpatterns = [
  ...
  url(r'^index$', views.index, name='url名称'),
]

在html界面中,通过url标签进行动态引用

{% url '应用名:url名称' %}
{% url '应用名:url名称' 位置参数1 位置参数2 %}
{% url '应用名:url名称' 关键字参数1 关键字参数2 %}

参考:

{% url 'app01:index' %}
{% url 'app01:show_news' 1 2 %}
{% url 'app01:show_news2' category=1 pageNo=2 %}

reverse函数

问题: 类似的,在python代码中,同样存在上面所说的url硬编码不方便维护的问题

# views.py
def url_reverse(request):
  # url正则配置项修改后,此处url硬编码代码需要修改
  return redirect("/index")
  # return redirect("/show_news/1/2")
  # return redirect("/show_news2/1/2")

解决:使用reverse函数,动态生成url。

# views.py
def url_reverse(request):
  # 动态引用
  # url = reverse("应用名:url名称")
  # url = reverse("应用名:url名称", args=[位置参数])
  # url = reverse("应用名:url名称", kwargs={关键字参数})
  return redirect(url)

希望本文所述对大家基于Django框架的Python程序设计有所帮助。

Python 相关文章推荐
Python THREADING模块中的JOIN()方法深入理解
Feb 18 Python
在Python的Django框架下使用django-tagging的教程
May 30 Python
Python 爬虫多线程详解及实例代码
Oct 08 Python
python多进程中的内存复制(实例讲解)
Jan 05 Python
对python .txt文件读取及数据处理方法总结
Apr 23 Python
Python实现去除列表中重复元素的方法小结【4种方法】
Apr 27 Python
pandas 数据索引与选取的实现方法
Jun 21 Python
对python中的*args与**kwgs的含义与作用详解
Aug 28 Python
python实现监控阿里云账户余额功能
Dec 16 Python
Python实现仿射密码的思路详解
Apr 23 Python
numpy矩阵数值太多不能全部显示的解决
May 14 Python
Python Pandas list列表数据列拆分成多行的方法实现
Dec 14 Python
Django中间件基础用法详解
Jul 18 #Python
Python编写通讯录通过数据库存储实现模糊查询功能
Jul 18 #Python
Django 实现图片上传和显示过程详解
Jul 18 #Python
Django框架模型简单介绍与使用分析
Jul 18 #Python
python使用pandas处理excel文件转为csv文件的方法示例
Jul 18 #Python
django 2.2和mysql使用的常见问题
Jul 18 #Python
详解Python二维数组与三维数组切片的方法
Jul 18 #Python
You might like
PHP session常见问题集锦及解决办法总结
2007/03/18 PHP
ionCube 一款类似zend的PHP加密/解密工具
2010/07/25 PHP
PHP下对数组进行排序的函数
2010/08/08 PHP
PHP实现根据浏览器跳转不同语言页面代码
2013/08/02 PHP
php取得字符串首字母的方法
2015/03/25 PHP
List Information About the Binary Files Used by an Application
2007/06/18 Javascript
Ext JS Grid在IE6 下宽度的问题解决方法
2009/02/15 Javascript
基于JQuery的数字改变的动画效果--可用来做计数器
2010/08/11 Javascript
鼠标滑上去后图片放大浮出效果的js代码
2011/05/28 Javascript
js 字符串转化成数字的代码
2011/06/29 Javascript
javascript-表格排序(降序/反序)实现介绍(附图)
2013/05/30 Javascript
JavaScript 学习笔记之变量及其作用域
2015/01/14 Javascript
JavaScript的History API使搜索引擎抓取AJAX内容
2015/12/07 Javascript
JS仿JQuery选择器功能
2017/03/08 Javascript
Vue2 配置 Axios api 接口调用文件的方法
2017/11/13 Javascript
vue移动端UI框架实现QQ侧边菜单组件
2018/03/09 Javascript
vue.js使用v-model指令实现的数据双向绑定功能示例
2018/05/22 Javascript
vue.js 双层嵌套for遍历的方法详解, 类似php foreach()
2018/09/07 Javascript
vue router带参数页面刷新或回退参数消失的解决方法
2019/02/27 Javascript
Vue插件从封装到发布的完整步骤记录
2019/02/28 Javascript
微信小程序导入Vant报错VM292:1 thirdScriptError的解决方法
2019/08/01 Javascript
Node.js系列之连接DB的方法(3)
2019/08/30 Javascript
[48:31]DOTA2-DPC中国联赛 正赛 Dynasty vs XG BO3 第一场 2月2日
2021/03/11 DOTA
Python实现拷贝多个文件到同一目录的方法
2016/09/19 Python
详解python3安装pillow后报错没有pillow模块以及没有PIL模块问题解决
2019/04/17 Python
Python 中Operator模块的使用
2021/01/30 Python
CSS3的first-child选择器实战攻略
2016/04/28 HTML / CSS
阿里巴巴英国:Alibaba英国
2019/12/11 全球购物
表彰大会策划方案
2014/05/13 职场文书
2015年扫黄打非工作总结
2015/05/13 职场文书
2015年生活老师工作总结
2015/05/27 职场文书
毕业生学校组织意见
2015/06/04 职场文书
董存瑞观后感
2015/06/11 职场文书
2015教师节通讯稿
2015/07/20 职场文书
致男子1500米运动员的广播稿
2019/11/08 职场文书
Promise静态四兄弟实现示例详解
2022/07/07 Javascript