模板继承和自定义过滤器

  小编最近学习了 模板继承和自定义过滤器。

模板继承

  Django模版引擎中最强大也是最复杂的部分就是模版继承了。 模版继承可以让你创建一个基本的“骨架”模版,它包含您站点中的全部元素,并且可以定义能够被子模版覆盖的 blocks 。

  base.html 这个作为模板继承页 indexxx.html 在这个模板中实现继承和引用 ss.html 这个作为模板的引用页。

base.html代码如下:作为骨架模板。挖了 三 个坑,content,title,demo。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>{% block title %}this title{% endblock %}</title>
</head>
<body>
{% load rand %}
{% block content %}
    This is content
{% endblock %}<br>
{% block demo %}
    this is Demo
{% endblock %}
<br>
哈哈哈哈哈哈啊
{% block ad %}
这是广告
{% endblock %}
</body>
</html>

indexText.html:

  标红的部分处于block之外的。

  当我们打开了子模板的路径后,子模板中block包含的东西为覆盖掉父模板中同名block所包含的东西。若父模板中有东西没有被子模板覆盖,如上面父模板中的text。那么父模板中名为text的block的内容将会被继承下来到子模板中显示。

(浏览器 打开之后 并未出现红色部分的内容)可见indexText.html  中非继承block不能显示。

<!DOCTYPE html>
<html lang="en">
{% extends 'student/base.html' %}
{% block title %} hello world{% endblock %}
{% block content %}噜啦啦{{ block.super }} {% endblock %}
{% load rand %}
<body>
{% block demo %}This is indexDemo {% include 'student/ss.html' %}{% endblock %}
<br>
{% block ad %}
    index  广告 eeeeee
    {{ block.super }}
{% endblock %}

{% block rand %}
    this is rand function
{% endblock %}
大家好!!
</body>

自定义过滤器

* 在项目目录下,创建一个名为common的python包
* 将common加到settings文件中的installed_app
* 在common目录templatetags里面创建自定义过滤器和标签文件

* 也可以在app内创建templatetags

templatetags文件夹中存放自定义模板和标签。

如图为 rand.py    —— 定义的过滤器

from django.template import Library
register = Library()

def mycut(value,arg):
    return value.replace(arg,'')

register.filter('mycut',mycut)

将定义的过滤器放到 base.html中:

{% load rand %}
<h1>{{ 'lhgfdaaaafgh' | mycut:'a' }}</h1>
<h1>{{ tn | mycut:'a' }}</h1>

 

用装饰器的方法写自定义的过滤器:

装饰器:

def funa(fun):
    def funb(a):
        print(111)
        print(a)
        fun()
    return funb

@funa
def func():
    print(2222)


func(333)

输出:

333
2222
funb

在rand.py中注册

@register.filter(name='mylower')
def mylower(value):
    return value.lower()

base.html:

<h1>{{ 'ASSSS' | mylower }}</h1>

文本显示结果

asss

 自定义标签

简单标签django.template.Library.simple_tag()
包含标签django.template.Library.inclusion_tag()

tag()方法有两个参数:
1. 模板标记的名称 - 字符串。 如果省略,将使用编译函数的名称。
2. 编译的函数 – 一个Python函数(不要把函数名写成字符串)
与过滤器注册一样,也可以将其用作装饰器。

@register.simple_tag
def current_time(format_string):
    return datetime.now().strftime(format_string)

@register.simple_tag(takes_context=True)  # 表示可以从上下文中获取参数  context
def current_time2(context):
    format_string = context.get('format_string')
    return datetime.now().strftime(format_string)

自定义包含标签的例子:
包含标签的功能是可以通过渲染另外一个模板来显示一些数据
例如很多地方都可能会用到下面这几行代码,除了choices这个变量不一样之外,其他的都是格式都一样时,那么我们就可以把这部分代码封装在一个包含标签中.

student/show_tag.html

<ul>
{% for i in choices %}
<li>{{ i }}</li>
{% endfor %}
</ul>

 

@register.inclusion_tag('student/show_tag.html')
def show_tag(*li):
    li = ['python', 'java', 'c++']
    return {'choices':li}

 显示结果:

  • python
  • java
  • c++
posted @ 2020-03-29 15:49  为红颜  阅读(134)  评论(0编辑  收藏  举报