django -- 过滤器

16 篇文章 0 订阅
10 篇文章 0 订阅

* 常见过滤器 
* 自定义过滤器
* 模板结构优化 
* 加载静态文件   

## 复习  

```
settings.py 中有一个  TEMPLATES 配置
BASE_DIR 你的项目目录  
'DIRS': [os.path.join(BASE_DIR, 'templates')]  项目目录下templates文件夹   
也就是说  render render_to_string 会来这里 查找模板 

     #'DIRS': [r"C:\templates"]  可以自定义主 templates 文件夹位置  

'APP_DIRS': True, 要记得 在 settings.py中 
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'book'  #加入你创建的应用  要不然找不到这个模板  
]
APP_DIRS 为True 保证 每个app 都到自己目录下面的templates 然后将'DIRS': []为空  

都没有 抛异常 templatedoesnotexists 异常  

```

## with 标签   

```
模板中想要定义变量  可以使用with语句    

{#    <p>{{ people.0 }}</p>#}
{#    <p>{{ people.0 }}</p>#}
{#    <p>{{ people.0 }}</p>#}
这个方式 有点 麻烦   

可以使用下面两种方法   
   {% with zelinx=people.0 %}   要求  =号前后 不能有 空格   
        <p>{{ zelinx }}</p>
        <p>{{ zelinx }}</p>
        <p>{{ zelinx }}</p>
    {% endwith %}

    {% with people.0 as qulinx %}
        <p>{{ qulinx }}</p>
        <p>{{ qulinx }}</p>
        <p>{{ qulinx }}</p>
    {% endwith %}
```

## verbatim  标签      

>  后期做项目 可能不止 DTL模板引擎 还有 https://github.com/aui/art-template  或者 vue       verbatim  标签    能够让  两个模板引擎共存        

```
项目过程中 模板引擎 可能不止django自带的 DTL 还有 VUE VUE也是{{ }} 为了让部分代码  使用vue 解析方法    


可以对 这部分代码  用  
 {% verbatim %}
        {{ 这里的代码用vue或者 art-template引擎 解析    }}
    {% endverbatim %}
    
 其它 用DTL来解析  
 
   {{ person.0 }}        这个输出的是  zhangsan   
    {% verbatim %}
        {{ kangbazi }}   这个输出的 是    {{kangbazi}}
    {% endverbatim %}
```

## 常用的过滤器   

```
其实就是 函数  我们可以通过在 模板中定义函数 来实现  我们的 目的  
在 DTL模板中  不支持  圆括号传递参数   
{{greet('ee')}} 
正确的语法是 : 
{{value|函数名字:值}}
```

### add  

将值和参数转成整型以后进行相加    如果不能转成整型  将值和参数 进行拼接  

> {{value|add:参数}}

```
源代码 : 
    def add(value, arg):
    """Add the arg to the value."""
    try:
        return int(value) + int(arg)
    except (ValueError, TypeError):
        try:
            return value + arg
        except Exception:
            return ''
            
            
 示例代码: 
      context = {
        'num1':4,
        'num2':10,
    }
    
    {{ num1|add:num2}}  返回14  
```

### cut 过滤器  类似于 python中的replace  移除值中指定的字符串     

> {{value|cut:""}}

```
{{ "hello world"|cut:"hello" }}  #返回的结果 world 
```

### date 时间过滤器  

```
{{value|date:""}}

{{ today|date:"Y-m-d h:i:s" }}

    Y 四位数年份 
    m 两位数月份  1-9  01-09 
    n 1-9 前面不加0  
    d 两位数字的天  
    h 小时  12小时  0前缀  
    i 分钟  0前缀
    s 秒  0前缀  
    H 小时  24小时制  0前缀  
    G 小时  前面没有 0前缀   
```

### default 过滤器  

```
{{value|default:"默认值"}}

判断 value 是否为真   如果真 显示 value的值  如果为假 显示默认值     


为false的情况  [] "" None {}
```

### default_if_none

```
{{value|default_if_none:"默认值"}}

只有 value 值为   None的时候  才显示默认值  如果 "" [] {} 认定为真   显示空字符串 等   

 context = {
        'value':None
    }
```

### first  返回 列表  元组  字符串的第一个元素  

```
{{value|first}}

```

### last  返回 列表  元组  字符串的最后一个元素

```
{{value|last}}
```

### floatformat  使用四舍五入的方式 格式化 一个浮点类型   

```
{{value|floatformat}} 默认保留一位小数点  
3.00000  返回 3 
3.1415  返回3.1 
3.15 返回3.2 四舍五入 保留一位小数点  


{{ value|floatformat:3 }} 保留3位小数点    
```

### join 将列表  元组 字符串  使用 符号进行拼接

```
{{value|join:"@"}} 
```

### length   列表  元组 字符串  字典的长度  

```
{{value|length}}
```

### lower  所有的字符串 转成小写 

```
{{value|lower}}
```

### upper 所有的字符串转成大写    

```
{{value|upper}}
```

### random  随机取出  列表 元组 字符串中的任意一值  点名器   

```
{{value|random }}
```

### safe 

>   {{ value|safe }}

```
标记 里边的字符串是安全的  你不用给我转义 
views.py
'value1':"<p>hello world</p>",
'value2':"<p>hello world</p>"
safe.html
{{ value1|safe }}
{{ value2 }}
结果:
hello world
<p>hello world</p>
```

### slice  类似于python中的切片操作     

```
{{ value|slice:"0:"}} 
从0开始截取到最后
{{ value|slice:"0::2"}} 

  context = {
        'value':"0123456789"
    }
   
  输出02468
```

### striptags 删除字符串中所有的 html标签   

```
{{ value|striptags }}

 context = {
        'value':"<script>alert('我的每一支笔都知道你的名字')</script>"
    }      
最后输出 alert('我的每一支笔都知道你的名字')  
```

###  truncatechars  如果给定的字符串超过了  过滤器要求的长度   那么就会进行切割  然后拼接 ... 作为省略号  

```
{{value|truncatechars:5}} 5这里 合理是指  2个字符+3个点 


context = {
        'value':"<p>小爷,欢迎下次光临</p>"
    }   
最后结果: <p...
```

### truncatechars_html  如果给定的字符串超过了  过滤器要求的长度   那么就会进行切割  然后拼接 ... 作为省略号 跟上面的区别是  它不切割 html标签  只切割字符串  

```
context = {
        'value':"<p>小爷,欢迎下次光临</p>"
    }
    
{{ value|truncatechars_html:6 }}

最终结果 
<p>小爷,...</p>
```

-------------------以上都是 DTL内置过滤器 相当于系统提前给你写好的函数   但是有时候还不能满足所有的需求 这个时候需要自定义 过滤器 也叫自定义函数   记住 过滤器最多两个参数  ----------

## 自定义  过滤器   

* 模板的过滤器必须放在 app中   而且这个app 必须要安装在 settings.py 的INSTALLED_APPS 中  然后在app下面创建一个 python包    这个包的名字 必须叫   templatetags 在包里再创建一个python文件 

  ```
  目录结构: 
      book
          models.py
          views.py
          urls.py
          templatetags 
              my_filter.py
  ```


* 到settings.py  INSTALLED_APPS写上应用的名字 

* 接下来 就是在my_filter.py写过滤器代码  但是 毕竟是python的函数  必须要将  这个过滤器 注册到  模板中 以后在这个模板中 就可以使用这个函数了     

* 过滤器最多两个参数     

* 过滤器的第一个参数 永远是被过滤的那个参数  也就是  | 左边 那个 

* 然后将其注册到 模板中  

* 最后在页面上 要 {%load  my_filter%}

     #### 示例代码  

```
from django import  template
register = template.Library()   #这里是产生一个注册对象 
def kangbazi(value,word):
    return value+word

register.filter("kangbazi",kangbazi)  #将其注册进去
                这是在页面上显示的名字   后面是自定义的名字  


{% load my_filter %}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>自定义过滤器 自定义函数 </title>
</head>
<body>
    {{ value|kangbazi:"下次再来" }}
</body>
</html>

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值