W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
自定義過濾器只是常規(guī)的 Python 函數(shù),過濾器左邊作為第一個參數(shù),其余的參數(shù)作 為額外的參數(shù)或關(guān)鍵字參數(shù)傳遞到過濾器。
例如在過濾器?{{?42|myfilter(23)?}}?中,函數(shù)被以?myfilter(42,?23)?調(diào) 用。這里給出一個簡單的過濾器示例,可以應(yīng)用到 datetime 對象來格式化它們:
def datetimeformat(value, format='%H:%M / %d-%m-%Y'):
return value.strftime(format)
你可以更新環(huán)境上的?filters?字典來把它注冊到模板環(huán)境上:
environment.filters['datetimeformat'] = datetimeformat
在模板中使用如下:
written on: {{ article.pub_date|datetimeformat }}
publication date: {{ article.pub_date|datetimeformat('%d-%m-%Y') }}
也可以傳給過濾器當(dāng)前模板上下文或環(huán)境。當(dāng)過濾器要返回一個未定義值或檢查當(dāng)前的autoescape?設(shè)置時很有用。為此,有三個裝飾器:?environmentfilter()?、?contextfilter()和?evalcontextfilter()?。
這里是一個小例子,過濾器把一個文本在 HTML 中換行或分段,并標(biāo)記返回值為安全 的 HTML 字符串,因為自動轉(zhuǎn)義是啟用的:
import re
from jinja2 import evalcontextfilter, Markup, escape
_paragraph_re = re.compile(r'(?:\r\n|\r|\n){2,}')
@evalcontextfilter
def nl2br(eval_ctx, value):
result = u'\n\n'.join(u'<p>%s</p>' % p.replace('\n', '<br>\n')
for p in _paragraph_re.split(escape(value)))
if eval_ctx.autoescape:
result = Markup(result)
return result
上下文過濾器工作方式相同,只是第一個參數(shù)是當(dāng)前活動的?Context?而 不是環(huán)境。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: