网络编程
位置:首页>> 网络编程>> Python编程>> Python模板的使用详细讲解

Python模板的使用详细讲解

作者:许小许520  发布时间:2022-03-20 13:24:08 

标签:Python,模板

一 模板语法传值

方式一:

# urls.py
path('template', views.template)
# views.py
def template(request):
   name = "jasper"
   age = "18"
   return render(request, 'template.html', {"name": name, "age": age})

 <p>姓名:{{ name }}  年龄:{{ age }}</p>

Python模板的使用详细讲解

方式二:关键字locals

def template(request):
   name = "jasper"
   age = "18"
   return render(request, 'template.html', locals())

传值范围:

  • 基本数据类型直接传递使用。

  • 函数名的传递会自动加括号执行并展示函数返回值(如果函数需要参数,则不会执行,也不会展示),模板语法不支持有参函数。

  • 类名的传递也会自动加括号产生对象。

  • 对象的传递则直接引用。

二 过滤器

add

{{ value|add:"2" }}

如果 value 是 4,那么输出将是 6。

这个过滤器将首先尝试将两个值强制转为整数。如果失败了,它将尝试将两个值加在一起。这对某些数据类型(字符串、列表等)有效,而对其他类型则失败。如果失败,结果将是一个空字符串。

capfirst

{{ value|capfirst }}

将值的第一个字符大写。如果第一个字符不是字母,这个过滤器就没有效果。

如果 value 是 &ldquo;django&rdquo;,则输出为 &ldquo;Django&rdquo;。

center

在给定宽度的字段中使数值居中。

"{{ value|center:"15" }}"

如果 value 是 &ldquo;Django&rdquo;,输出将是 " Django "。

cut

从给定的字符串中删除参数的所有值。

{{ value|cut:" " }}

如果 value 是 &ldquo;String with spaces&rdquo;,输出将是 &ldquo;Stringwithspaces&rdquo;。

date

根据给定的格式设置日期。

Python模板的使用详细讲解

Python模板的使用详细讲解

例子:

{{ value|date:"D d M Y" }}

如果 value 是一个 datetime 对象(例如,datetime.datetime.datetime.now() 的结果),输出将是字符串 &lsquo;Wed 09 Jan 2008&rsquo;。

传递的格式可以是预定义的 DATE_FORMAT、DATETIME_FORMAT、SHORT_DATE_FORMAT 或 SHORT_DATETIME_FORMAT, 或者是使用上表中显示的格式指定器的自定义格式。请注意,预定义的格式可能会根据当前的 locale 而有所不同。

假设 USE_L10N 为 True 和 LANGUAGE_CODE 为例如 &ldquo;es&rdquo;,那么对于:

{{ value|date:"SHORT_DATE_FORMAT" }}

输出将是字符串 &ldquo;09/01/2008&rdquo; (Django 自带的 &ldquo;SHORT_DATE_FORMAT&rdquo; 格式指定符是 &ldquo;d/m/Y&rdquo;)。

当不使用格式字符串时,使用 DATE_FORMAT 格式指定器。假设设置与前一个例子相同:

{{ value|date }}

输出 9 de Enero de 2008 (DATE_FORMAT&rsquo; 格式指定符为 r&rsquo;j\d\e F\d\e Y&rsquo;)。&ldquo;d&rdquo; 和 &ldquo;e&rdquo; 都是反斜杠,因为否则每一个都是一个格式字符串,分别显示日期和时区名称。

你可以将 date 与 time 过滤器结合起来,以呈现一个 datetime 值的完整表示。例如:

{{ value|date:"D d M Y" }} {{ value|time:"H:i" }}

default

如果值为 False,则使用给定的默认值。否则,使用该值。 例子:

{{ value|default:"nothing" }}

如果 value 是 &ldquo;&rdquo; (空字符串),输出将是 nothing。

更多内置过滤器请查看官方文档:https://docs.djangoproject.com/zh-hans/4.1/ref/templates/builtins/#ref-templates-builtins-filters

三 标签

参考官方文档:https://docs.djangoproject.com/zh-hans/4.1/ref/templates/builtins/#ref-templates-builtins-filters

四 自定义模板标签和过滤器

Django 模板语言包含了很多 内置 tags 和 filters,设计目的是满足应用需要占位逻辑需求。极少情况下,你可能发现需要的功能未被核心模板集覆盖。你能通过 Python 代码自定义 tags 和 filters 扩展集成模板引擎,通过 {% load %} 标签使其可用。

该应用应包含一个 templatetags 目录,与 models.py, views.py 等同级。若该目录不存在,创建它&mdash;&mdash;不要忘了用 init.py 文件确保目录被视作一个 Python 包。

自定义的 tags 和 filters 会保存在模块名为 templatetags 的目录内。模块文件的名字即稍候你用来加载 tags 的名字,所以小心不要采用一个可能与其它应用自定义的 tags 和 filters 冲突的名字。

为了使 {% load %} 标签生效,包含自定义标签的应用必须包含在 INSTALLED_APPS 中。这是个安全特性:它允许你在一个主机上持有多个模板库,而不是让每个 Django 安装都能访问所有的库。

我们并未限制放入 templatetags 包中的模块数量。只需牢记 {% load %} 语句会加载名字指定 Python 模块的 tags/filters,而不是应用。

要成为一个可用的 tag 库,模块必须包含一个名为 register 的模块级变量,它是一个 template.Library 实例。所有的 tags 和 filters 均在其中注册。所以,在模块的开始,输入以下内容:

from django import template
register = template.Library()

4.1 自定义过滤器

@register.filter(name='myfilter')
def my_add(a, b):
   return a + b

4.2 自定义标签函数

@register.simple_tag(name='mt')
def func(a, b, c, d):
   return a + b + c + d

4.3 自定义inclusion_tag

@register.inclusion_tag(filename='it.html')
def index(n):
   html = []
   for i in range(n):
       html.append('第%s页'%i)
   return locals()

参考官方文档:https://docs.djangoproject.com/zh-hans/4.1/howto/custom-template-tags/

五 模板的继承

# 在html页面打上标记
{% block 名字 %}
    html标签
{% endblock %}

# 扩展html界面
{% extends 'html文件' %}

{% block 名字 %}
    html标签
{% endblock %}

# 一般情况下模板中至少应该有三个区域
css、js、content

子板中还可以使用母板的内容 {{ block.super }}

六 模板的导入

将html页面的某个部分当做模块的形式导入使用

{% include 'menu.html' %}

来源:https://blog.csdn.net/weixin_68531269/article/details/126668940

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com