Django丨模块

    技术2026-01-14  9

    Django模块


    在HelloWorld目录下创建templayes目录,并建立hello.html文件

    HelloWorld/ |-- HelloWorld | |-- __init__.py | |-- __init__.pyc | |-- settings.py | |-- settings.pyc | |-- urls.py | |-- urls.pyc | |-- views.py | |-- views.pyc | |-- wsgi.py | `-- wsgi.pyc |-- manage.py `-- templates `-- hello.html

    hello.html文件代码

    <h1>{{ hello }}</h1>

    模板中变量使用双括号

    建好模板之后还需说明模板文件路径,修改HelloWorld/settings.py,修改中TEMPLATES中的DIRS。

    ...TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [ os.path.join(BASE_DIR, 'templates) ], # 修改位置 'APP_DIRS': True, 'OPTIONS': { 'context_processors': [ 'django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages', ], }, }, ] ...

    Django模板标签

    变量

    模板语法

    view:{"HTML变量名" : "views变量名"} HTML:{{变量名}}

    HelloWorld/HelloWorld/views/py文件

    from django.shortcuts import render def runoob(request): views_name = "world" return render(request,"runoob.html", {"name":views_name})

    templates中的hello.html

    <p>{{ name }}</p>

    列表

    templates中的hello.html中,可以用.索引下标取出对应的元素。

    from django.shortcuts import render def runoob(request): views_list = ["wordl1","world2","world3"] return render(request, "hello.html", {"views_list": views_list})

    HelloWorld/templates/hello.html文件代码:

    <p>{{ views_list }}</p> # 取出整个列表 <p>{{ views_list.0 }}</p> # 取出列表的第一个元素

    字典

    templates中的runoob.html中,可以用.键取出对应的值

    from django.shortcuts import render def runoob(request): views_dict = {"name":"world"} return render(request, "runoob.html", {"views_dict": views_dict})

    HelloWorld/templayes/hello.html文件代码

    <p>{{ views_dict }}</p> <p>{{ views_dict.name }}</p>

    过滤器

    模板语法

    {{ 变量名 | 过滤器:可选参数 }}

    模板过滤器可以在变量被显示前修改它,过滤器使用管道字符

    {{ name|lower }}

    {{ name }}变量被过滤器lower处理后,文档大写转换文本为小写。

    过滤管道可以被“套接”,即是说,一个过滤器管道的输出又可以作为下一个管道的输入

    # 将第一个元素转换为大写 {{ my_list|first|upper }}

    其他过滤器

    addslashes:添加反斜杠到任何反斜杠、单引号或者双引号前面date:按指定的格式字符串参数格式化date或者datetime对象 {{ pub_date|date:"F j, Y" }}

    length:返回变量的长度

    default default为变量提供一个默认值

    如果views传的变量的布尔值是false,则使用指定的默认值

    HelloWorld/HelloWorld/views.py文件代码

    from django.shortcuts import render def runoob(request): name =0 return render(request, "hello.html", {"name": name})

    HelloWorld/templates/hello.html

    {{ name|default:"world" }}

    filesizeformat 以更易读的方式显示文件的大小(即13KB,4.1MB等)

    safe

    将字符串标记为安全,不需要转义。

    要保证views.py传过来的数据绝对安全,才能用safe。和后端views.py的mark_safe效果相同。

    Django会自动对views.py传到HTML文件中的标签语法进行转义,令其语义失效。

    加safe过滤器是告诉Django该数据是安全的,不必对器进行转义,可以让该数据语义生效。

    HelloWorld/HelloWorld/views.py文件代码

    from django.shortcuts import render def runoob(request): views_str = "<a href='https://www.baidu.com/'>点击跳转</a>" return render(request, "hello.html", {"views_str": views_str})

    HelloWorld/templates/hello.html

    {{ views_str|safe }}

    if/else标签

    基本语法格式如下

    {% if condition %} ... display {% endif %}

    或者

    {% if condition1 %} ... display 1 {% elif condition2 %} ... display 2 {% else %} ... display 3 {% endif %}

    根据条件判读是否输出,支持嵌套

    HelloWorld/HelloWorld/views.py文件代码

    from django.shortcuts import render def runoob(request): views_num = 88 return render(request, "hello.html", {"num": views_num})

    HelloWorld/templates/hello.html

    {%if num > 90 and num <= 100 %} 优秀 {% elif num > 60 and num <= 90 %} 合格 {% else %} 一边玩去~ {% endif %}

    for标签

    {% for %}允许在一个序列上迭代

    与Python的for语句的情形类似。

    每一次循环中,模块系统会渲染在{% for %}和{% endfor %}之间的所有内容。

    {% for i in views_list %} {{ i }} {% endfor %}

    遍历字典可以直接用字典**.items**方法,用变量的解包分别获取键和值。

    {% for i,j in views_dict.items %} {{ i }}---{{ j }} {% endfor %}

    在{% for %}标签里可以通过{{ forloop }}变量获取循环序号。

    forloop.counter 顺序获取循环序号,从1开始计算forloop.counter() 顺序获取循环序号,从0开始计算 {% for i in listvar %} {{ forloop.counter }} # 顺序获取循环序号,从 1 开始计算 {{ forloop.counter0 }} # 顺序获取循环序号,从 0 开始计算 {{ forloop.revcounter }} #倒叙获取循环序号,结尾序号为 1 {{ forloop.revcounter0 }} # 倒叙获取循环序号,结尾序号为 0 {{ forloop.first }} # 第一条数据返回 True,其他数据返回 False {{ forloop.last }} # 最后一条数据返回 True,其他数据返回 False {% endfor %}

    {% empty %}

    可选的{% empty %}从句:在循环为空的时候执行

    {% for i in listvar %} {{ forloop.counter0 }} {% empty %} 空空如也~ {% endfor %}

    ifequal/ifnotequal标签

    {% ifequal %}标签比较两个值,当它们相等时,显示在{% ifequal %}和{% endifequal %}之中所有的值。

    {% ifequal user currentuser %} <h1>Welcome!</h1> {% endifequal %}

    和{% if %}类似,支持可选的{% else %}标签

    {% ifequal section 'sitenews' %} <h1>Site News</h1> {% else %} <h1>No News Here</h1> {% endifequal %}

    注释标签

    注释使用{# #}

    {# 这是一个注释 #}

    include标签

    {% include %}标签允许在模板中包含其他的模块的内容

    {% include "nav.html" %}

    csrf_token

    csrf_token用于form表单中,作用是跨站请求伪造保护。

    如果不用该标签,在用form表单时,跳转页面会报403权限错误。

    自定义标签和过滤器

    1、在app目录下创建templatestags目录(目录名只能是templatestags)

    2、在templatetags目录下创建任意py文件

    3、在该py文件下

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

    4、利用装饰器@register.filter自定义过滤器

    注:装饰器的参数最多只能有2个

    @register.filter def my_filter(v1, v2): return v1 * v2

    5、利用装饰器@register.simple_tag自定义标签

    @register.simple_tag def my_tag1(v1, v2, v3): return v1 * v2 * v3

    6、在使用自定义标签和过滤器之前,要在html文件body的最上方导入该.py文件

    {% load my_tags %}

    7、在HTML中使用自定义过滤器

    {{ 11|my_filter:22 }}

    8、在HTML中使用自定义标签

    {% my_tag1 11 22 33 %}

    9、语义化标签

    在该.py文件中导入mark_safe

    from django.utils.safestring import mark_safe

    在定义标签是,用上mark_safe方法,令标签语义化,相当于jQuery中的html()方法。

    和前端HTML文件中的过滤器safe效果一样。

    @register.simple_tag def my_html(v1, v2): temp_html = "<input type='text' id='%s' class='%s' />" %(v1, v2) return mark_safe(temp_html)

    配置静态文件

    1、在项目根目录下创建statics目录

    2、在settings文件的中配置添加以下配置

    STATIC_URL = '/static/' # 别名 STATICFILES_DIRS = [ os.path.join(BASE_DIR, "statics"), ]

    3、在static目录下创建css目录,js目录,images目录,plugins目录,分别放css文件,js文件,图片,插件。

    4、吧bootstrap框架放入插件目录plugins。

    5、在HTML文件的head标签中引入bootstrap

    注:此时引用路径中的要用配置文件中的别名static,而不是目录static。

    在模板中使用需加入{% load static %}代码。

    模板及成果

    模板可以用继承的方式来实现复用,较少冗余内容

    网页的头部和尾部内容一般都是一致的,就可以通过模板继承来实现复用。

    父模板用于防止可重复利用的内容,子模版继承父模板的内容,并放置自己的内容。

    父模板

    标签block…endblock(挖坑):父模板中的预留区域,该区域留给子模版填充差异性的内容,不同预留区域名字不能相同。

    {% block 名称 %} 预留给子模板的区域,可以设置设置默认内容 {% endblock 名称 %} 子模版

    子模版使用标签extends继承父模板

    {% extends "父模板路径"%}

    子模版如果没有设置父模板预留区域的内容,则使用在父模板设置的默认内容,当然也可以都不设置,就为空。

    Processed: 0.022, SQL: 9