如何理解Django4.1_template中的变量和过滤器
admin
2023-07-16 15:03:59
0

一.简述
在现在的web实际开发中,为了更加规范的编码及方便后期的项目规划,我们要求前后端分离,前端更进一步要求布局(HTML)、样式(CSS)、行为(JS)分离。在django中,我们把template分离出来作为一个独立的模块来处理HTML。本章节主要讲解django中的template模块的使用。
二.模板语法
模板组成:HTML+逻辑代码
三.模板之逻辑代码
1.模板渲染的原理
两个概念:
template:模板
context:上下文
渲染原理(过程):
A.Django先通过Template生成一个实例化template对象;
B.Diango再通过Context生成一个实例化context对象;
C.Djangi通过template实例调用渲染方法(例如:render())来渲染生成结果;
如图:
如何理解Django4.1_template中的变量和过滤器
代码块如下:

from django.template import Template,Context
template = Template("welcome to {{name}}.")
context = Context({'name':'浙江'})
template.render(context)
'welcome to 浙江.'

注:以上的过程是在django内部实现的,比较复杂,所以我们直接使用django封装好的方法实现该效果即可,即render(request,’template对象文件’,data)或render(request,’template对象文件’,local())
同一个模板对象可以重复使用。
2.模板之变量
2.1格式:{{varname}}
在HTML中使用双引号包裹变量名,再通过view中将变量对应的值传过来(传值有两种方式:1.{key:value};2.locals())。
实例代码如下:
如何理解Django4.1_template中的变量和过滤器
如何理解Django4.1_template中的变量和过滤器
如何理解Django4.1_template中的变量和过滤器
2.2变量的类型及变量深度查询
变量可以是字符串、字典、列表、元组、对象等等。
如图:
如何理解Django4.1_template中的变量和过滤器

如何理解Django4.1_template中的变量和过滤器
页面效果图:
如何理解Django4.1_template中的变量和过滤器
注:在template中使用的均是深度查询,即只能通过符号.(点)进行下一级查询且所有的序列数据类型均能使用索引正常查询但不能使用方括号的格式,只能使用var.index的格式,不能使用var[index]或dic[key]的格式。
2.3
3.模板之过滤器
注:该部分图片来自网络(如有侵权,联系删除)
如何理解Django4.1_template中的变量和过滤器
如何理解Django4.1_template中的变量和过滤器
如何理解Django4.1_template中的变量和过滤器
如何理解Django4.1_template中的变量和过滤器
如何理解Django4.1_template中的变量和过滤器

4.重点:自定义过滤器filter
上面给去了一些常用的过滤器,也是django给我们提供好的方法,但是如果需要某些特定功能的函数呢?而django只是提供了公用的方法,此时我们可以使用django的filter的自定义方法。
1.首先需要使用的app中创建templatetags模块(必须要有且为Package文件类型)
2.在templatetags模块中新建任意.py文件,如:mytags.py
3.在py文件中自定义相应的filter函数代码,如下所示:

from django import template
from django.utils.safestring import mark_safe
register = template.Library()       #register的名字是固定的,不可改变

#自定义一个multi函数
@register.filter
def multi(x,y):         #自定义过滤器函数
    return x*y

#自定义一个multi函数
@register.simple_tag
def tag_multi(x,y,z):       #自定义标签函数
    return x*y*z

4.在要使用自定义的filter函数的HTML文件中导入之前创建的mytags.py文件,即:{% load mytags %}

{% load mytags %}



    
    myfilter


    

{{ person.name }}的年龄为:{{ person.age}}

    

{{ person.name }}的年龄*10为:{{ person.age|multi:10 }}

5.在该HTML文件中使用自定义filter函数,如下:

{% load mytags %}



    
    myfilter


    

{{ person.name }}的年龄为:{{ person.age}}

    

{{ person.name }}的年龄*10为:{{ person.age|multi:10 }}

       {# 使用自定义的filter函数 #}

6.注意:a要在setting中的INSTALLED_APPS配置当前的app,如下图,不然django会无法找到自定义的mytags.py文件。b.新建mytags.py文件后重启该项目;c.filter函数只能接收2个参数(大括号|前面一个为此处的第一个参数)。
如何理解Django4.1_template中的变量和过滤器

7.最终在浏览器上显示效果如图所示:
如何理解Django4.1_template中的变量和过滤器

8.总结图:
如何理解Django4.1_template中的变量和过滤器

相关内容

热门资讯

美媒:拜登家族不肯消失,民主党... 美国将于今年年底举行中期选举,民主党人有望夺回众议院。然而拜登家族的高调举动,使得民主党再次分心,一...
对日本新型军国主义的“新型抗战... 【文/观察者网专栏作者 江宇舟】日本这几个月的对华行为,已经是全方位的恶声、恶气、恶行、恶法:自卫队...
“这里没有口号,只有实干”——... 在黄河科技学院,有这样一个地方:没有惊天动地的口号,没有花里胡哨的“形象工程”,有的只是实验室里彻夜...
AI决定6G成败关键? 专家称... 中经记者 陈佳岚 广州报道 “6G与AI的增强融合,这部分OPPO是全力投入的。而与AI的融合,也是...
自贡:“智造”为核,无人车跑出... 盐都初夏清晨,和勤劳的人们一同早起的,还有一辆辆造型新颖的无人配送车、清扫作业车。市民杨先生对此颇有...
黄仁勋不装了:所有芯片市场我全... 来源:市场资讯 (来源:科技头版) 英伟达要当AI时代唯一的王。 出品 | 科技头版 作者 | 青...
Ducky展出平价磁轴键盘OK... IT之家 6 月 3 日消息,键盘品牌 Ducky(吉利鸭)在 COMPUTEX 2026 上带来了...
从工具到底座:私有化即时通讯如... 随着企业数字化建设从单点应用走向整体架构,即时通讯系统的角色正在发生根本性转变——它不再只是一个员工...
运行超11年后失联,NASA正... 【文/观察者网 陈思佳】 当地时间6月3日,美国国家航空航天局(NASA)发布消息称,环绕火星运行...
Meta开发者AI模型一再跳票... 来源:环球网 【环球网科技综合报道】6月4日消息,据《华尔街日报》援引知情人士消息报道,Meta已...