Django(自定义过滤器和自定义标签)

  • 模版是一个用django模版语言标记过的python字符串。模版可以包含模版标签和变量。
  • 模版标签是在一个模版里起作用的标记。比如,一个模版标签可以产生控制结构的内容(if或者for),可以获取数据库内容或者访问其它模版标签。
  • 一个标签块被{%%}包围
  • 变量标签被{{}}包围
  • context是一个传递给模版的key-value对。
  • 模版渲染是通过从context获取值来替换模版中变量并执行所有的模版标签。

创建自定义标签目录

首先在app底下创建一个templatetags目录,添加一下两个.py文件

__init__.py 
extra_tags.py目录结构如下

在 setting 中作为app进行注册
INSTALLED_APPS = [
    ‘django.contrib.admin‘,
    ‘django.contrib.auth‘,
    ‘django.contrib.contenttypes‘,
    ‘django.contrib.sessions‘,
    ‘django.contrib.messages‘,
    ‘django.contrib.staticfiles‘,
    ‘blog‘,
    ‘mysites.templatetags‘,#作为app注册

]

在extratags.py 中添加自定义过滤器

from django import template

register = template.Library()

@register.filter(name=‘cut‘)  # 过滤器在模板中使用时的name
def myCut(value, arg):  # 把传递过来的参数arg替换为‘转换后‘
    return value.replace(arg, ‘转换后‘)

编辑试图函数,把value传递给模板文件

def  index(request):
    return render(request, ‘index.html‘,{‘value‘:‘Hello Small Nine‘})

添加urls 路由控制

urlpatterns = [
    path(‘admin/‘, admin.site.urls),
    path(‘login/‘,views.login),
    path(‘index/‘,views.index),
]

最终启动结果显示

原文地址:https://www.cnblogs.com/mjiu/p/9763776.html

时间: 2024-08-01 14:49:19

Django(自定义过滤器和自定义标签)的相关文章

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

前提:自定义模板标签和过滤器必须位于Django的某个应用中,这个应用可以包含一个templatetags目录, 和models.py views.py 处于同一级目录.若这个templatetags目录不存在则创建他,同时在该目录下建立一个py文件:__init__.py 文件,使得该目录可以作为Python包.在添加这个模块后,需要重启服务器以便使用.注意命名不要冲突.eg: polls/ __init__.py models.py templatetags/ 在模板中可以这样用:{% lo

django自定义过滤器及模板标签

创建一个模板库 不管是写自定义标签还是过滤器,第一件要做的事是创建模板库(Django能够导入的基本结构). 创建一个模板库分两步走: 第一,决定模板库应该放在哪个Django应用下. 如果你通过 manage.py startapp 创建了一个应用,你可以把它放在那里,或者你可以为模板库单独创建一个应用. 我们更推荐使用后者,因为你的filter可能在后来的工程中有用. 无论你采用何种方式,请确保把你的应用添加到 INSTALLED_APPS 中. 我们稍后会解释这一点. 第二,在适当的Dja

vue学习(二):自定义过滤器和自定义指令

#自定义指令 自定义指令的参数有: el: 指令所绑定的元素,可以用来直接操作 DOM . binding: 一个对象,包含以下属性: name: 指令名,不包括 v- 前缀. value: 指令的绑定值, 例如: v-my-directive="1 + 1", value 的值是 2. oldValue: 指令绑定的前一个值,仅在 update 和 componentUpdated 钩子中可用.无论值是否改变都可用. expression: 绑定值的字符串形式. 例如 v-my-di

实现MVC自定义过滤器,自定义Area过滤器,自定义Controller,Action甚至是ViewData过滤器

MVC开发中几种以AOP方式实现的Filters是非常好用的,默认情况下,我们通过App_Start中的FilterConfig来实现的过滤器注册是全局的,也就是整个应用程序都会使用的,针对单独的Filter我们不得不去单独的Controller或者Action去定义 如图: 那么问题来了,我现在想在FitlerConfig里面去维护所有的过滤器,但是又想实现自定义的过滤器该咋搞,MVC默认不支持! 我们先来看看,MVC默认的Fitlers注册是怎样的官方源码:GlobalFilterColle

自定义模板语言之simple_tag和自定义过滤器

扩展你的模板系统 一般是扩展模板的tag和filter两个功能.可以用来创建你自己的tag和filter功能库. 创建模板库 分为两步: 1. 首先决定由模板库在哪一个注册的app下放置,你可以放在一个已有的app目录下,也可以新建一个专门管理模板库的app,比如python manage.py startapp myTemplateLibrary.推荐后者,因为可以方便将来的重用. 2. 在app目录下创建templatetags子目录,并在里面创建两个文件,__init__.py,用来声明这

flask中自定义过滤器

第一种方法: 1,第一步:自定义过滤器函数 # 自定义一个函数,将list里面的数据进行排序 def list_sort(list) return list.sort() 2.第二步:注册过滤器 第一个参数是函数名,第二个参数是调用名 app.add_template_filter(list_sort, "sort1") 3,注册成功后就可以在模板中进行调用 <p>{{list | sort1}}</p> ============================

django自定义过滤器及标签的布置

1:在app文件下新建templatetags,文件名不可改,django运行时会自动寻址. 2:templatetags下新建py文件. 3:py文件里需要引用申明:from django import template // 引入模板 from django.utils.safestring import mark_safe //此句与mark_safe函数有关,使用不到可略去 register=template.Library() // 注册 4:py文件里定义函数体:def...(x,y

Django之模板层-自定义过滤器以及标签

自定义标签与过滤器 在settings中的INSTALLED_APPS配置当前app,不然django无法找到自定义的simple_tag. 在app中创建templatetags模块(模块名只能是templatetags) 创建任意 .py 文件,如:my_tags.py from django import template # 该对象名必须是register register = template.Library() #自定义过滤器装饰器 @register.filter def mult

django 第五课自定义模板过滤器与标签

代码布局:(自定义的代码放在哪里) 某个app特有的 app目录下,templatetags文件夹需要放 __init__.py 在到templetags文件夹下创建python模块(py文件) 定义复用 创建要给新的app,将他们定义在新的app中,在INSTALL_APPS 注册,然后可以应用 自定义模板过滤器 模板过滤器是什么? 函数,一个或两个参数 第一个参数是传递进来的模板变量 第二个参数,普通的参数,也可以是默认也可以不要其实就是个函数,没有什么不同在app目录teacher下创建t