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)

  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值