5

思路如下。我使用类似于 stackoverflow 的标签向 jinja2 发送一些文本。我如何告诉 jinja2 将它们视为包含文本的标记并在 html 中生成粗体、斜体等文本?

谢谢你。

4

2 回答 2

4

我习惯了django-markdown,所以我认为使用过滤器是实现此目的的好方法:

   <div class="content">{{ article.body|rst }}</div>

我不知道 jinja2 是否存在这样的过滤器,但它应该很容易编写。我猜这行中的一些东西(未经测试的代码):

from docutils.core import publish_parts
import jinja2

def rst_filter(s):
    return jinja2.Markup(publish_parts(source=s, writer_name='html')['body'])
environment.filters['rst'] = rst_filter
于 2012-07-03T11:31:41.583 回答
3

你应该能够做到这一点:

from docutils.core import publish_string
import jinja2

html = publish_string(source=text, writer_name='html')
node = jinja2.Markup(html)

Jinja 2 节点实际包含在node您的范围中的位置。

于 2012-07-03T11:29:24.093 回答