首页 > 其他 > 详细

自定义过滤器和标签

时间:2018-11-23 22:50:34      阅读:181      评论:0      收藏:0      [点我收藏+]

1、在settings中的INSTALLED_APPS配置当前app,不然django无法找到自定义的simple_tag.

2、在app中创建templatetags模块(模块名只能是templatetags)

3、创建任意 .py 文件,如:my_tags.py

from django import template
from django.utils.safestring import mark_safe
 
register = template.Library()   #register的名字是固定的,不可改变
 
 
@register.filter
def filter_multi(v1,v2):
    return  v1 * v2
<br>
@register.simple_tag
def simple_tag_multi(v1,v2):
    return  v1 * v2
<br>
@register.simple_tag
def my_input(id,arg):
    result = "<input type=‘text‘ id=‘%s‘ class=‘%s‘ />" %(id,arg,)
    return mark_safe(result)

 

4、在使用自定义simple_tag和filter的html文件中导入之前创建的 my_tags.py

{% load my_tags %}   # load 会循环找所有app下的templatetags下的文件

5、使用simple_tag和filter(如何调用)

-------------------------------.html
{% load xxx %}  
      
# num=12
{{ num|filter_multi:2 }} #24
 
{{ num|filter_multi:"[22,333,4444]" }}
 
{% simple_tag_multi 2 5 %}  参数不限,但不能放在if for语句中
{% simple_tag_multi num 5 %}

注意:filter可以用在if等语句后,simple_tag不可以

{% if num|filter_multi:30 > 100 %}
    {{ num|filter_multi:30 }}
{% endif %}
6.@register.inclusion_tag:

先理解include标签,

include 标签

    • {% include %} 标签允许在模板中包含其它的模板的内容。
    • 下面这个例子都包含了 nav.html 模板
      {% include "nav.html" %}
      ?
include标签,定义的模板数据是死的只有模板内容;而过滤器和自定义标签是定义数据的。@register.inclusion_tag可以将这两者结合在一起。
还是在
templatetags下的文件中:
web.py:
from django.template import Library
import re
register =Library()

@register.inclusion_tag("rbac/menu.html")
def get_menu_styles(request):
    permission_menu_list = request.session.get("permission_menu_list")
    for item in permission_menu_list:
        if re.search("^{}$".format(item["url"]), request.path):
            item["class"] = "active"

    return {"permission_menu_list":permission_menu_list}

数据会先交给rbac/menu.html渲染,再以字符串形式返回;谁调用就传给谁

rbac/menu.html:

<div class="static-menu">

        {% for item in permission_menu_list %}
            <a href="{{ item.url }}" class="{{ item.class }}">
                <span class="icon-wrap"><i class="fa {{ item.icon }}"></i></span> {{ item.title }}
            </a>
        {% endfor %}

</div>

可以直接返回渲染后的数据,且解决了代码的复用性,谁用直接调就行

调用::

layout.html :

 {% load web %}  <!--调用-->
 {% get_menu_styles request %}

实例:

点击标签加入active样式:
     
        解决思路1:
            每一个返回母版的视图函数中:
                permission_menu_list = request.session.get("permission_menu_list")
                for item in permission_menu_list:
                    if re.search("^{}$".format(item["url"]), request.path):
                        item["class"] = "active"
            
        解决思路2:    引入inclusion_tag方法:
                @register.inclusion_tag("rbac/menu.html")
                def get_menu_styles(request):
                    permission_menu_list = request.session.get("permission_menu_list")
                    for item in permission_menu_list:
                        if re.search("^{}$".format(item["url"]), request.path):
                            item["class"] = "active"

                    return {"permission_menu_list":permission_menu_list}
            
            
            在layout.html中:
                     <div class="menu-body">
            
                           {% load web %}
                           {% get_menu_styles request %}

                    </div>

 

 



自定义过滤器和标签

原文:https://www.cnblogs.com/zwq-/p/10010053.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!