flask学习之jinja2模板自带的过滤器

  • jinja2模版过滤器
    管道符号|连接的
    过滤器相当于一个函数,吧当前的变量传入到过滤器中,过滤器根据自己的功能进行渲染,比如输入大写时但是显示为小写,输入小写显示为大写字母等操作。
    jinja自带的过滤器很多,下文将介绍调用方式。
from flask  import Flask,render_template
app = Flask(__name__)
@app.route('/')
def index():
    context = {
        'username': 'lcy',
        'age':-18,
        'home':'tj',
        'es':"<script>alert('hello')</script>"
        #'name':'lcy1992'

    }
    return render_template('index.html',**context)

if __name__ == '__main__':
    app.run(debug=True)
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<!--<p></p>-->
    <h1>首页</h1>
    <p>{{ username }}</p>
    <h5>{{ age|abs }}</h5>
    <p>{{ name|default('这个人很懒,什么都没留下')}}</p>
<!--    关闭转义功能-->
    {% autoescape off %}
    <p>{{ es }}</p>
    {% endautoescape %}
    <p>{{ es|safe }}</p>

<!--    <p>{{ es }}</p>-->
</body>
</html>

常用过滤器方法:
• abs(value):返回一个数值的绝对值。
• default(value,default_value,boolean=false):如果当前变量没有值,则会使用参数中的值来代替。name|default(‘juran’)——如果name不存在,则会使用juran来替代。boolean=False默认是在只有这个变量为undefined的时候才会使用default中的值,如果想使用python的形式判断是否为false,则可以传递boolean=true。也可以使用or来替换。
• escape(value)或e:转义字符,会将<、>等符号转义成HTML中的符号。例如:content|escape或content|e。
• first(value):返回一个序列的第一个元素。names|first。
• format(value,*arags,**kwargs):格式化字符串。例如以下代码:
{{ “%s” - “%s”|format(‘Hello?’,“Foo!”) }}将输出:Helloo? - Foo!
• last(value):返回一个序列的最后一个元素。示例:names|last。
• length(value):返回一个序列或者字典的长度。示例:names|length。
• join(value,d=u’’):将一个序列用d这个参数的值拼接成字符串。
• safe(value):如果开启了全局转义,那么safe过滤器会将变量关掉转义。示例:content_html|safe。
• int(value):将值转换为int类型。
• float(value):将值转换为float类型。
• lower(value):将字符串转换为小写。
• upper(value):将字符串转换为小写。
• replace(value,old,new): 替换将old替换为new的字符串。
• truncate(value,length=255,killwords=False):截取length长度的字符串。
• striptags(value):删除字符串中所有的HTML标签,如果出现多个空格,将替换成一个空格。
• trim:截取字符串前面和后面的空白字符。
• string(value):将变量转换成字符串。
• wordcount(s):计算一个长字符串中单词的个数。

测试了其中部分过滤器,代码如下:

from flask  import Flask,render_template
app = Flask(__name__)
@app.route('/')
def index():
    context = {
        'username': 'lcy',
        'age':-18,
        'home':'tj',
        'es':"<script>alert('hello')</script>",
        #'name':'lcy1992'
        'book':['python','java','PHP','shell'],
        'height':1.83,
        'weight':200,
        'address': '天津市   静海区  梁头镇   西柳木村'

    }
    return render_template('index.html',**context)

if __name__ == '__main__':
    app.run(debug=True)

HTML代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<!--<p></p>-->
    <h1>首页</h1>
    <p>{{ username }}</p>
    <h5>{{ age|abs }}</h5>
    <p>{{ name|default('这个人很懒,什么都没留下')}}</p>
<!--    关闭转义功能-->
<!--    {% autoescape off %}-->
<!--    <p>{{ es }}</p>-->
<!--    {% endautoescape %}-->
<!--    <p>{{ es|safe }}</p>-->
    <p>{{ book|first }}</p>
    <p>{{ book|last }}</p>
    <p>{{ book|length }}</p>
    <p>{{ book|first|length }}</p>
    <p>{{ book|first|last }}</p>
    <p>{{ book|join(d='-') }}</p>
    <p>{{ height|int }}</p>
    <p>{{ weight|float }}</p>
    <p>{{ book[0]|upper }}</p>
    <p>{{ book[2]|lower }}</p>
    <p>{{ book|replace('python','lcy') }}</p>
    <p>{{ address|wordcount }}</p>
<!--    取列表中字符串的首字母末字母没成功 -->
<!--    <p>{{ es }}</p>-->
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值