0
可能重複:
Why is this Jinja nl2br filter escaping <br>'s but not <p>'s?有沒有更好的方法來應用帶有Jinja/Flask的nl2br過濾器?
我使用的是神社與瓶(啓用autoescape),我嘗試應用this filter
import re
from jinja2 import evalcontextfilter, Markup, escape
_paragraph_re = re.compile(r'(?:\r\n|\r|\n){2,}')
app = Flask(__name__)
@app.template_filter()
@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
的問題吧是它永遠不會適用< br>的,並且總是在每條線周圍應用< p>。
如果鍵入:
1
2
3
4
在一個textarea
,它就會被保存到DB爲 「U'\ r \ N2 \ r \ n \ r \ N3 \ r \ N4' 」,當把與神社| nl2br過濾它出來作爲
<p>1</p>
<p>2</p>
<p>3</p>
<p>4</p>
我找它是
<p>1<br>2</p>
<p>3<br>4</p>
這個正則表達式的方法似乎是大材小用我後。請告訴我他們是一個更簡單的方法來實現這一點,因爲我一直拉着我的頭髮整天試圖找出它...