1

我想用 Github 风格的 Markdown 替换我正在构建的 Django 博客中的标准 Markdown 实现。我想使用Misaka,并且我已经将我自己的自定义模板标签放在一起。不幸的是,有些事情出了差错。

这是我的模板标签文件,位于blog/templatetags/gfm.py. 该__init__.py文件存在于同一文件夹中:

from django import template
from django.template.defaultfilters import stringfilter
import misaka as m

register = template.Library()

@register.filter(is_safe=True)
@stringfilter
def gfm(value):
    rendered_text = m.html(value,
                           extensions=m.EXT_FENCED_CODE,
                           render_flags=m.HTML_ESCAPE)
    return rendered_text

这是我的模板之一:

{% extends 'layout/base.html' %}

{% block header %}
{% endblock %}

{% block content %}
{% load gfm %}
{% if object_list %}
{% for post in object_list %}

<div class="post">
    <div class="page-header">
        <h1><a href="{{ post.get_absolute_url }}">{{ post.title }}</a></h1>
    </div>
{{ post.text|gfm }}
<p>Posted {{ post.pub_date }}</p>
<p>
{% for category in post.categories.all %}
    <a class="badge badge-info" href="/category/{{ category.slug }}/">{{ category.title }}</a>
{% endfor %}
</p>
</div>
{% endfor %}
<br />
<ul class="pager">
{% if page_obj.has_previous %}
<li class="previous"><a href="/{{ page_obj.previous_page_number }}/">Previous Page</a></li>
{% endif %}
{% if page_obj.has_next %}
    <li class="next"><a href="/{{ page_obj.next_page_number }}/">Next Page</a></li>
{% endif %}
</ul>
{% else %}
<div class="post">
<p>No posts matched</p>
</div>
{% endif %}

{% endblock %}

输出的文本被用双引号括起来,这破坏了整个事情。否则,生成的标记似乎是正确的。

我在这里哪里出错了?我知道这不是数据库中的数据,就好像我使用 pdb 来获取函数内部的值一样valuerendered_text它们被正确呈现。例如,这是一篇文章的纯文本版本,由以下人员打印pdb

u'A Python application:\r\n\r\n    print "Hello world"'

这是使用 Misaka 在 Markdown 中呈现的版本:

u'<p>A Python application:</p>\n\n<pre><code>print &quot;Hello world&quot;\n</code></pre>\n'

我对 Django 相当有经验,但我是自定义模板标签的新手。

4

1 回答 1

2

使用自动转义标签。

{% autoescape off %}{{ post.text|gfm }}{% endautoescape %}

或者,您可以使用安全过滤器。

{{ post.text|gfm|safe }}
于 2013-08-31T22:10:02.940 回答