Django模版过滤器Markdown

Django有很多内置的模板过滤器,允许你修改模板中的变量。过滤器看起来{{variable|my_filter}}。  

带参数的过滤器类似于{{variable|my_filter:"foo"}}。您可以对一个变量应用任意多的过滤器,例如,{{variable|filter1|filter2}},它们中的每一个都将应用于前面生成的输出。

创建一个自定义过滤器,以便能够在博客文章中使用markdown语法,然后在模板中将文章内容转换为HTML。

使用pip安装markdown模块

python -m pip install Markdown

编辑blog_tags.py

from django import template
from django.utils.safestring import mark_safe
import markdown

register = template.Library()

@register.filter(name='markdown')
def markdown_format(text):
    return mark_safe(markdown.markdown(text))

blog_tags的代码在自定义模版标签时创建,更多内容请看

Django自定义模版标签-CSDN博客

为了避免函数名和markdown模块之间的冲突,我们将函数名命名为markdown_format,并将过滤器名命名为markdown,以便在模板中使用,例如{{variable|markdown}}。  

Django会转义过滤器生成的HTML代码。使用Django提供的mark_safe函数将结果标记为模板中呈现的安全HTML。

t默认情况下,Django不会信任任何HTML代码,并且会在将其放入输出之前进行转义。唯一的例外是那些被标记为可安全转义的变量。

现在,在帖子列表和详细信息模板中加载模板标记模块。

在blog/post/list.html和blog/post/detail.html模板的顶部{% extends %}标签之后添加以下一行:

{% load blog_tags %}

编辑 post/detail.html模版
{{ post.body|linebreaks }}
替换为
{{ post.body|markdown }}

编辑post/list.html 模版
{{ post.body|truncatewords:30|linebreaks }}
替换为
{{ post.body|markdown|truncatewords_html:30 }}

truncatewords_html过滤器在一定数量的单词之后截断字符串,避免未关闭的HTML标记。

有关自定义过滤器更多信息,请查看如何编写自定义的模板标签和过滤器 | Django 文档 | Django (djangoproject.com)

你可能感兴趣的:(django,python)