python-django_自定义标签和过滤器_模板的导入与继承_静态文件使用方式_inclusion_tag的用法

11 篇文章 0 订阅

django

1. 自定义标签和过滤器

1. 自定义过滤器

-第一步:
	在settings中的INSTALLED_APPS配置当前app,不然django无法找到自定义的simple_tag
    
-第二步:
	在app中创建templatetags包(包名只能是templatetags,不能改)
    
-第三步:
	在包内,新建py文件(如:my_tags.py)
    
-第四步:
	# 写代码(过滤器)
    from django import template
    register = template.Library()
    @register.filter
    def my_upper(value):
        return value.upper()
    
-第五步:
	#(模板),先load,再使用
    {% load my_tags %}
    {{ 'aa'|my_upper }}

2. 自定义标签

-第一步:
	在settings中的INSTALLED_APPS配置当前app,不然django无法找到自定义的simple_tag
    
-第二步:
	在app中创建templatetags包(包名只能是templatetags,不能改)
    
-第三步:
	在包内,新建py文件(如:my_tags.py)
    
-第四步:
    # 写代码(过滤器)
    from django import template
    register = template.Library()
    @register.simple_tag
    def my_csrf():
        import uuid
        res=uuid.uuid4()
        return mark_safe('<input type="hidden" name="csrfmiddlewaretoken" value="%s">'%res)
    
-第五步:
    #(模板),先load,再使用
    {% load my_tags %}
    {% my_csrf %}
    {% my_tag 1 3 4 %} 

2. 模板的导入与继承

1. 模板的导入

-第一步:
	# 新建一个 xx.html,把好看的模板写入
    <div class="panel panel-danger">
        <div class="panel-heading">
            <h3 class="panel-title">重金求子</h3>
        </div>
        <div class="panel-body">
       		详情点击:<a href="http://www.baidu.com">疯狂点我</a>
        </div>
    </div>
    
-第二步:
	# 放在你想使用的地方
	{% include 'xx.html' %}

2. 模板的继承

-第一步:
	# 写一个母版模板文件
    	base.html
    # 写空盒子
        {% block top %}

        {% endblock %}
    
-第二步:
	# 某个页面要使用母版,引入
    {% extends 'base.html' %}
    # 扩写盒子
    {% block top %}
    	index页面
    {% endblock %}

3. 静态文件使用方式

# settings.py 文件中静态文件相关配置
STATIC_URL = '/static/'

STATICFILES_DIRS = [
    os.path.join(BASE_DIR,'static'),
]

# 静态文件三种使用方式
第一种: 
	<link rel="stylesheet" href="/static/bootstrap/css/bootstrap.min.css">
    
第二种:
    {% load static %}
    <link rel="stylesheet" href="{% static 'bootstrap/css/bootstrap.min.css' %}">
    
第三种:
    {% load static %}
    <link rel="stylesheet" href="{% get_static_prefix %}bootstrap/css/bootstrap.min.css">

# 特殊用法
	{% load static %}
    {% static "images/hi.jpg" as myphoto %}
    <img src="{{ myphoto }}"></img>
    
    {% load static %}
	{% get_static_prefix as static %}
	<img src="{{ static }}images/hi.jpg" alt="Hi!"/>

4. inclusion_tag 用法

# inclusion_tag作用: 
	可以生成一片模板中的代码块
    
# 使用方法
	-第一步:
    	在settings中的INSTALLED_APPS配置当前app,不然django无法找到自定义的simple_tag
        
    -第二步:
    	在app中创建templatetags包(包名只能是templatetags,不能改)
        
    -第三步:
    	在包内,新建py文件(如:my_tags.py)
        
    -第四步:
    	# 写代码(inclusion_tag)
        # inclusion_tag,传一个模板文件
        @register.inclusion_tag('left.html')
        def left(num):
            # dic={0:第0页,1:第1页,2:第2页} 字典推导式
            dic = {i: '第%s页' % i for i in range(num)}
            # 固定返回的必须是字典
            print(dic)
            return {'data': dic}

        @register.inclusion_tag('beautiful.html')
        def beautiful(title, url):
            return {'title': title, 'url': url}
        
    -第五步使用:
    	#(模板),先load,再使用
    	{% load my_tags %}
		{% left 5 %}
        {% beautiful '名字' '地址' %}   
        
# inclusion_tag与tag的区别
	-tag需要在代码中写html的东西
    -inclusion_tag代码跟模板分离

5. 补充

针对 encode 和 decode 记混问题

# 方式一
	a = 'abcde' # type str
    a.提示信息
    
# 方式二
	ss_str = str(request.body,encoding='utf-8')
    ss_bytes = bytes('字符串变量',encoding='utf-8')
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

I believe I can fly~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值