我想用 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 来获取函数内部的值一样value
,rendered_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 "Hello world"\n</code></pre>\n'
我对 Django 相当有经验,但我是自定义模板标签的新手。