08.Django自定义模板,自定义标签和自定义过滤器

简介: 一:自定义模板 模板继承我们可以简单的理解为类的继承,其实他们有很大的相似之处,定义一个基类模板,我们便可以在子页面中进行引用,django中模板中的块用block进行标示,他属于django自定义的tag 例如:我们定义了一个基类的模板base.

一:自定义模板

模板继承我们可以简单的理解为类的继承,其实他们有很大的相似之处,定义一个基类模板,我们便可以在子页面中进行引用,django中模板中的块用block进行标示,他属于django自定义的tag

例如:我们定义了一个基类的模板base.html

<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <meta name="description " content="Thinkgamer 博客" />
    <meta name="keywords" content="Thinkgamer 博客" />
    <title>{% block title %}{% endblock %}</title>
    <link type="text/css" rel="stylesheet" href="/static/css/base_css/base_logre.css" />
</head>
<body>
    <script language="JavaScript">
        {% if error %}
            alert("{{ error }}");
        {% endif %}
    </script>

    <a class="logo" href="/"><img src="/static/image/login.png" /></a>
    <h2 class="lrr-sub">CYANSCIKIT</h2>

    {%  block container%}
    {% endblock %}

    <div class="hmc-copyright"> Copyright 2014-2015  |  版本1.0 |  Made By CyanScikit </div>
</body>
</html>
login.html 继承base模板

{% extends "base_logre.html" %}

{% block title %}
欢迎登陆CyanScikit科技网站
{% endblock %}
{% block container %}
<div class="reg-log-main login">
        <div class="rlm_content">
            <form action="" method="post">
                <div class="rlmcl_content phone">
                    <input type="text" name="account"  id="user" placeholder="用户名" />
                </div>
                <div class="rlmcl_content pwd">
                    <input type="password" name="password"  id="pwd" placeholder="密码" />
                </div>
                <p>
                    <input type="radio" name="check" />记住密码
                </p>
                <div class="log_reset">
                    <button class="btn" id="enterlogin" onClick="check()">登 录</button>
                    <span>
                        <a style="float:left;cursor:pointer" href="/index/index" >随便看看<i></i></a>
                        <a style="float:right;cursor:pointer" href="/logre/regeister">新手注册<i></i></a>
                    </span>
                </div>
            </form>
        </div>
    </div>
{% endblock %}
regeister.html 继承base.html

{% extends "base_logre.html" %}

    {% block container %}
    <div class="reg-log-main regist">
        <form action="" method="post">
            <div class="rlm_content">
                <div class="rlmcl_content phone">
                    <input type="text" name="name" id="user" placeholder="用户名" />
                </div>
                <div class="rlmcl_content pwd">
                    <input type="password" id="password" name="pwd" placeholder="密码" />
                </div>
                <div class="log_reset">
                    <button class="btn" id="enterlogin">注  册</button>
                    <span>
                        <a style="float:left;cursor:pointer" href="/index/index" target="_blank">随便看看<i></i></a>
                        <a style="float:right;cursor:pointer" href="/logre/login" >账户登录<i></i></a>
                    </span>
                </div>
            </div>
        </form>
    </div>
    {% endblock %}

效果图如下:



二:自定义标签

其实前边已经提到了django的标签功能,django自身提供了许多标签,例如if, for, block.....但这并不能满足我们实际开发中的需求,幸好django支持自定义标签,下面我们拿个例子来详细说一下

比如我们要定义一个upper的标签,其作用是将字符串全部转换为大写

首先在你要加载这个tag的app中新建一个Python Package,创建一个upper.py

#coding:utf-8
from django import template

register = template.Library()

class upperNode(template.Node):
    def __init__(self,nodelist):
        self.nodelist = nodelist

    def render(self, context):
        content = self.nodelist.render(context)
        return content.upper()

@register.tag
def upper(parser,token):
    nodelist = parser.parse("endupper") #指定结束符
    parser.delete_first_token()

    return upperNode(nodelist)

我是在logre的模块下创建的,然后在login.html中加载:

{% load  upper %}
{% upper %}
    这是我自定义的标签{{ test }}
{% endupper %}
login函数传参如下:

return render_to_response("logre/login.html", {"test":"test",})
前端显示如下:


其他更加有趣的tag还请大家自己动手实现

三:自定义过滤器

自定义过滤器其实和自定义标签是很相似的,其目的都是为了使显示达到自己想要的内容或者格式
创建 assets.py,和二中tag在同一目录下,其作用是在全局变量的变动下加载不同的css
首先在settings.py文件中 设置一个变量  IS_DEVELOP=True,作用是当问true时加载测试的css,False时加载正常用的css

asserts.py:
#coding:utf-8

from django import template

from my_blog.settings import IS_DEVELOP

register = template.Library()

@register.filter
def assets(value):
    if IS_DEVELOP:
        return "/static/css/test.css"
    return "/static/css/base_css/base_logre.css"

在base.html中做如下修改
{% load assets %}
<link type="text/css" rel="stylesheet" href="{{ '/static/css/base_css/base_logre.css | assets' }}" />

这边这个图是IS_DEVELOP为True时的情况:

css链接为: <link type="text/css" rel="stylesheet" src="/static/css/test.css" />

下面是IS_DEVELOP为false时:

css链接: <link type="text/css" rel="stylesheet" src="/static/css/base_css/base_logre.css" />

哈哈,又恢复正常了吧
相关文章
|
4月前
|
Shell 数据库 网络架构
Django+DRF 实战:从异常捕获到自定义错误信息(下)
本文详解了 Django REST Framework 中 ValidationError 的验证流程与优先级,涵盖字段内置验证、自定义验证方法、对象级验证及数据库约束,并通过实战演示如何自定义异常提示信息。
138 1
Django+DRF 实战:从异常捕获到自定义错误信息(下)
|
3月前
|
缓存 监控 中间件
Django中间件自定义开发指南:从原理到实战的深度解析
Django中间件是Web应用的“交通警察”,在请求与响应过程中进行全局处理,适用于身份验证、日志记录、性能监控等功能。本文详解中间件的工作原理、开发步骤及实战案例,帮助开发者掌握自定义中间件的构建方法,提升Django应用的可维护性与扩展性。
256 0
|
4月前
|
Python
Django+DRF 实战:自定义异常处理流程
本文详解DRF异常处理流程,包括默认处理机制与自定义异常处理器的实现方法。通过源码分析和实战示例,讲解如何全局捕获并统一返回错误信息,并结合日志记录与友好提示提升项目健壮性。适用于Django进阶开发。
193 4
|
5月前
|
中间件 数据库 Python
Django实战:自定义中间件实现全链路操作日志记录
Django中间件是一套轻量级插件系统,用于全局处理请求与响应。通过自定义中间件可实现如操作日志记录等功能,支持在请求、视图、响应及异常阶段插入逻辑。本文详解中间件生命周期、编写方式及实战案例。
126 1
|
4月前
|
数据安全/隐私保护 网络架构 UED
Django+DRF 实战:从异常捕获到自定义错误信息
本文介绍了DRF(Django REST framework)中的异常处理机制,重点讲解了内置异常类ValidationError的使用场景与示例。同时通过用户注册功能的实战演示,展示了如何在序列化器中自定义参数校验规则,并在视图中捕获并返回结构化的错误信息,提升接口的健壮性与用户体验。
112 0
|
安全 数据库 数据安全/隐私保护
|
前端开发 JavaScript 数据库
python Django教程 之模板渲染、循环、条件判断、常用的标签、过滤器
python Django教程 之模板渲染、循环、条件判断、常用的标签、过滤器
|
数据库 Python
django中数据库外键可以自定义名称吗
django中数据库外键可以自定义名称吗
|
Java C++ Python
django 模板 过滤器
django 模板 过滤器
|
API Java 数据库连接
从平凡到卓越:Hibernate Criteria API 让你的数据库查询瞬间高大上,彻底告别复杂SQL!
【8月更文挑战第31天】构建复杂查询是数据库应用开发中的常见需求。Hibernate 的 Criteria API 以其强大和灵活的特点,允许开发者以面向对象的方式构建查询逻辑,同时具备 SQL 的表达力。本文将介绍 Criteria API 的基本用法并通过示例展示其实际应用。此 API 通过 API 构建查询条件而非直接编写查询语句,提高了代码的可读性和安全性。无论是简单的条件过滤还是复杂的分页和连接查询,Criteria API 均能胜任,有助于提升开发效率和应用的健壮性。
446 0