首页 > 其他分享 >Django模板语法

Django模板语法

时间:2024-03-11 21:35:18浏览次数:22  
标签:forloop return list Django 语法 html def my 模板

Django模版语法

(1)传数据

  • 模版语法可以传递的后端python数据类型(可迭代)
  • 后端:
def test2(request):
    name = 'heart'
    float = 11.11
    str_name = '你好'
    boolean_test = True
    list_test = [1, 2, 3]
    tuple_test = (1, 2, 3)
    dict_test = {'name': 'heart', 'age': 18}
    set_test = {1, 2, 3, 4, 5, 5}
    return render(request,'mubanyufa.html', locals())
  • 前端:
<body>
{{ name }}
<br>
{{ float }}
<br>
{{ str_name }}
<br>
{{ boolean_test }}
<br>
{{ list_test }}
<br>
{{ tuple_test }}
<br>
{{ dict_test }}
<br>
{{ set_test }}
<br>
</body>
<!-- 
heart
11.11
你好
True
[1, 2, 3]
(1, 2, 3)
{'name': 'heart', 'age': 18}
{1, 2, 3, 4, 5} 
-->

(2)传函数

  • 传递函数名会自动加括号调用 但是模版语法不支持给函数传额外的参数

  • 后端:

def test2(request):
    name = 'heart'

    def func():
        return '这是一个函数'  # 一定要有返回值
    return render(request,'mubanyufa.html', locals())
  • 前端:
<body>
{{ func }} # 会自动调用 但是函数里面的参数传不进来
</body>

(3)传类

  • 传类名的时候也会自动加括号调用(实例化)
  • 后端:
def test2(request):
    class MyClass(object):
        def get_self(self):
            return 'self'

        @staticmethod
        def get_func():
            return 'func'

        @classmethod
        def get_class(cls):
            return 'cls'

    obj = MyClass()
    return render(request,'mubanyufa.html', locals())
  • 前端:
<body>
{{ MyClass }} # <app01.views.test2.<locals>.MyClass object at 0x000001DAA6A2E740>
{{ obj }} # <app01.views.test2.<locals>.MyClass object at 0x000001DAA69D6470>
{{ obj.get_class }} # cls
{{ obj.get_func }} # func
{{ obj.get_self }} # self
</body>

(4)小结

  • 内部能够自动判断出当前的变量名是否可以加括号调用 如果可以就会自动执行 针对的是函数名和类名

  • Django模版语法的取值 是固定的格式 只能用句点符 .

(5)过滤器

{{数据|过滤器:参数}}
{{ value|filter_name:参数 }}
  • 过滤器就类似于是模版语法内置方法
  1. date: 格式化日期。例如:{{ my_date|date:"Y-m-d" }}
  2. length: 获取列表或字符串的长度。例如:{{ my_list|length }}
  3. filesizeformat: 获取文件大小。例如:{{ my_file|filesizeformat}}
  4. default: 设置默认值。例如:{{ my_var|default:"No value" }}
  5. lower: 将字符串转换为小写。例如:{{ my_string|lower }}
  6. upper: 将字符串转换为大写。例如:{{ my_string|upper }}
  7. truncatechars: 截断字符串到指定长度。例如:{{ my_string|truncatechars:9 }}
  8. truncatewords: 截断单词到指定长度。例如:{{ my_string|truncatewords:9 }}
  9. safe: 转义。例如:{{ my_string|safe }}
  10. join: 拼接。例如:{{ my_string|join:'123' }}
  11. slice: 切片。例如:{{ my_string|slice:'0:4:2' }}
  12. cut: 移除指定字符。例如:{{ value|cut:'1' }}

(6)标签

(1)for循环

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

(2)for循环可用的一些参数

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

(3)if判断

(1)if elif else

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

(2)if和else

{% if user_list|length > 5 %}
  你好
{% else %}
    世界
{% endif %}

(4)with

  • 定义一个中间变量,多用于给一个复杂的变量起别名。
  • 注意等号左右不要加空格。
{% with total=business.employees.count %}
    {{ total }} employee{{ total|pluralize }}
{% endwith %}
{% with business.employees.count as total %}
    {{ total }} employee{{ total|pluralize }}
{% endwith %}

(5)csrf_token

  • 这个标签用于跨站请求伪造保护。
  • 在页面的form表单里面写上

(6)forloop

list = ["你好", "我好", "大家好"]
{% for re in list %}

    <p>{{ forloop }}</p>

{% endfor %}
标签
{'parentloop': {}, 'counter0': 0, 'counter': 1, 'revcounter': 3, 'revcounter0': 2, 'first': True, 'last': False}

{'parentloop': {}, 'counter0': 1, 'counter': 2, 'revcounter': 2, 'revcounter0': 1, 'first': False, 'last': False}

{'parentloop': {}, 'counter0': 2, 'counter': 3, 'revcounter': 1, 'revcounter0': 0, 'first': False, 'last': True}
  • first
    • 标识 for 循环是否是第一次
  • last
    • 标识 for 循环是否是以后一次
  • counter0
    • 类似索引
  • counter
    • 计数
  • 取值

(1)if+forloop

{% for re in d %}
    {% if forloop.first %}
        <p>第一次循环</p>
    {% elif  forloop.last %}
        <p>最后一次循环</p>
    {% else %}
        <p>{{ re }}</p>
    {% endif %}
{% empty %}
    <p>for循环的对象是空,不支持for循环</p>

{% endfor %}

(7)自定义过滤器、标签、inclusion_tag

(1)自定义过滤器

  • 在应用下创建一个名字必须叫templatetags文件夹
  • 在该文件夹内创建任意名字的py文件 eg:mytag.py
  • 在该py文件内必须书写下面两句话
from django import template

register = template.Library()
  • 在templatetags下面的py文件:
from django import template

register = template.Library()


@register.filter(name='heart')
def mysum(v1, v2):
    return v1 + v2
  • 后端
def test2(request):
    float = 11.11
    return render(request,'mubanyufa.html', locals())
  • 前端
{% load mytag %}
<p>{{ float|heart:666 }}</p>

(2)自定义标签

  • 在templatetags下面的py文件:
from django import template

register = template.Library()


@register.simple_tag(name='plus')
def index(a,b,c,d):
    return '%s-%s-%s-%s'% (a,b,c,d)
  • 前端
  • 标签多个参数彼此之间空格隔开
<p>{% plus 'heart' 123 123 456 %}</p>

(3)自定义inclusion_tag

  • 先定义一个方法,在页面上调用该方法,并且可以传值,该方法会生成一些数据然后传递给一个html页面,之后将渲染好的结果放到调用的位置

  • 当html页面某一个地方的页面需要传参数才能够动态的渲染出来,并且在多个页面上都需要使用到该局部,那么就考虑将该局部页面做成inclusion_tag形式

  • 在templatetags下面的py文件:

from django import template

register = template.Library()

@register.inclusion_tag('left_menu.html')
def left(n):
    data = [f'第{i}项' for i in range(n)]
    return locals()
  • 前端
  • 标签多个参数彼此之间空格隔开
{% left 10 %}
  • left_menu.html
<ul>
    {% for foo in data %}
    <li>{{ foo }}</li>
    {% endfor %}
</ul>

image

(8)模版继承

  • 可以被修改的区域有:

    1. css区域
    2. html区域
    3. js区域
  • 页面整体大差不差,只是某一些局部在做变化,使用模版继承很方便

  • home.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>Title</title>
  {% block page-css %}
  
  {% endblock %}
</head>
<body>
{% block content %}
	模板内容
{% endblock %}
</body>
</html>

(1)继承模版

  • 在子页面中在页面最上方使用下面的语法来继承母板
{% extends 'home.html' %}
  • 修改模板就在子页面中定义母版的block名来对应替换相应的内容
{% block content %}
  <p>123</p>
  <p>456</p>
  <p>789</p>
{% endblock %}

(2)模板的导入

{% include 'test.html' %} 

(9)静态模版加载

(1)

  • 加载Django的静态文件
{% load static %}
<img src="{% static "images/hi.jpg" %}" alt="Hi!" />
  • 引用JS文件时使用:
{% load static %}
<script src="{% static "mytest.js" %}"></script>
  • 某个文件多处被用到可以存为一个变量
{% load static %}
{% static "images/hi.jpg" as myphoto %}
<img src="{{ myphoto }}"></img>

(10)导出项目模块版本

pip freeze > requirement.txt
  • 安装
pip install -r requirement.txt

标签:forloop,return,list,Django,语法,html,def,my,模板
From: https://www.cnblogs.com/ssrheart/p/18067114

相关文章

  • 10django
    作业(二次删除确认)#ajax结合sweetalert(ajax用于页面不刷新也可以提交数据,sweetalert是帮助美化删除二次确认的)1.下载源码只需要到dist文件夹内的css和js即可2.拷贝使用官网提供的案例代码3.添加配置参数新增等待特效<divclass="container"><divclass="row"......
  • 滑动窗口模板
    适用情景:字符串或数组的子串或子数组模板defslidingWindow(s,t):need={}#存储字符串t中各个字符的需求量window={}#存储滑动窗口中各个字符的出现次数forcint:#遍历字符串tneed.setdefault(c,0)#访问不存在的键时自动创建并......
  • 第六十九天 BBS项目之五 js与模板语法 inclusion_tag实操,文章详情,点赞点踩
    一、昨日内容回顾#1首页文章的渲染 -模板语法的for循环-bootstrap的媒体组-显示头像:articel.blog.userinfo有可能没有:在admin中建立关系 -注册---》申请开启博客功能-图标库 -font-awesome-4.7.0#2个人站点样式 -头部导航栏-......
  • django保存数据到表时,遇到字符集问题--已解决
    问题回归:在开发《测试平台imos》时,调用下载接口后,保存返回报文乱码包含一大堆??时,报错: 查询了下资料,是由于编码位数不同引起的,在mysql中默认的utf8是3位的:??表情已经超过了三位位,所以用三位空间储存空间肯定出问题。知道了原因那解决起来就简简单单了。解决方式:1.打开mysql......
  • django中的上传文件
    用django写接口的时候,不可避免的会涉及到上传文件环境python版本django版本djangorestframework版本drf-spectacular版本3.10.43.23.14.00.27.1编写模型fromdjango.dbimportmodelsclassTimeMixin(models.Model):"""时间混入类,为模型添加创......
  • 2024新版Axure RP大数据可视化大屏模板68套及通用组件+PSD文件
    AxureRP数据可视化大屏模板及通用组件库2024新版重新制作了这套新的数据可视化大屏模板及通用组件库V2版。新版本相比于V1版内容更加丰富和全面,但依然秉承“敏捷易用”的制作理念,这套作品也同样延续着我们对细节的完美追求,整个设计制作过程我们同样投入了大量的精力。作品制作前......
  • C陷阱与缺陷:语法陷阱
    @目录语法陷阱引入理解函数声明表达式什么是表达式表达式的目的声明函数名本质对复杂代码分析运算符的优先级switch语句悬挂else语法陷阱引入要理解一个C程序,仅仅理解组成该程序的符号是不够的。程序员还必须理解这些符号是如何组合成声明、表达式、语句和程序的。虽然这......
  • P5905 【模板】全源最短路(Johnson)
    原题链接题解发誓以后除了stl内置,其他时候结构体绝对不内置比较函数code#definelllonglong#include<bits/stdc++.h>usingnamespacestd;llin_q[3005]={0};llh[3005]={0};llvis[3005]={0};lldis[3003]={0};constllinf=1e9;struct{llto,val,head;}ed......
  • django 动态查询实现过程
    django动态查询实现过程一、背景描述在前端页面上有查询功能,要查询的输入选择有username,address,mobile等,可以通过任意一个查询,或者任意组合进行查询。后端,获取传入的数值。判断哪个有输入,再在数据库中进行查询二、解决方案根据条件,动态实现查询过程condition={}ifusern......
  • 学习Django【1】模型
    编辑models.py文件,改变模型。运行pythonmanage.pymakemigrations为模型的改变生成迁移文件。运行pythonmanage.pymigrate来应用数据库迁移。1、定义模型-也就是数据库结构设计和附加的其它元数据。大白话:数据库建表。2、使用命令pythonmanage.pym......