下面将创建一个Markdown语法的过滤器,帖子内容会自动转换成html格式
Markdown表示为一类纯文本语法格式且易于使用,旨在转换html(详情)
安装Python Markdown模块
pip inatall Markdown==2.6.11
注册过滤器(blog_tags.py)
默认状态下,django并不信任任何HTML代码,并在将其置于输出前进行定义,唯一的情况就是在转义的过程中使用mark_safe标记为安全变量,这种行为可防止django输出危险的HTML,并可为返回安全的HTML创建异常
#注册Markdown过滤器
@register.filter(name='markdown')
def markdown_format(text):
return mark_safe(markdown.markdown(text))
修改list.html
在{%extends%}下添加
{% load blog_tags %}
并且
{# {{ post.body|truncatewords:30|linebreaks }}注释掉添加为下列语句#}
{{ post.body|markdown|truncatewords_html:30 }}
修改detail.html
在{%extends%}下添加
{% load blog_tags %}
并且
{# {{ post.body|linebreaks }}注释掉添加为下列语句#}
{{ post.body|markdown }}
最后即可打开博客帖子添加页面,在输入区添加

结果为:

本文介绍了如何在Django中创建一个Markdown到HTML的模板过滤器,通过安装Python Markdown模块,注册过滤器,修改list.html和detail.html,确保帖子内容能以安全的HTML格式显示。
1568

被折叠的 条评论
为什么被折叠?



