django学习——过滤器truncatechars_html的用途详解

在主页如何显示博文的摘要。因为我们采用markdown语法实现文章的排版,如果采用过滤器slice或者truncatechars截取文章的前多少个字符时{{ content|safe|slice:“500” }},当恰好截取到包含有htlm标记的语法时,比如引用或图片时:

<code>
#配置404 500错误页面
def page_not_found(request):
    return render(request, '404.html')
</code>

如果恰好截取到中间,则前端显示一定会出现排版乱码的现象

原来django其实早就帮我们解决好这个问题了,通过过滤器truncatechars_html。

truncatechars_html

类似于truncatechars,除了它知道HTML标记。 在字符串中打开并且在截断点之前未关闭的任何标记在截断后立即关闭。

像这样:

{{ value|truncatechars_html:9 }}

如果value是“&lt; p&gt; Joel 是 a slug&lt; / p&gt; “,输出将为”&lt; p&gt; Joel i …&lt; / p&gt;“ t7 >。

HTML内容中的换行符将保留。

这样,就可以避免截取到html中的标记而出现乱码的情况了。

{{ content|safe|truncatechars_html:500 }}

作者:geerniya
来源:CSDN
原文:https://blog.csdn.net/geerniya/article/details/79347534

猜你喜欢

转载自blog.csdn.net/qq_35531549/article/details/86609346