原理,是通过markdown库将markdow文档转化成html,然后将字符串传给html,
再使用django的功能 加上safe,让它把原样html给 模板。 {{markdown_str_text | safe}}
1.安装
#将md文档转换成html文件
# pip install markdown
2.如下内容, 就是markdown库的功能,将md文档转化成html同时把结果传给html
这里利用的render,还可以用通用视图类generic.TemplateView
def show1(request):
content1 = '''MD文档'''
md5_content = markdown.markdown(content1, extensions=[
'markdown.extensions.extra', # 转化标题,字体等
'markdown.extensions.codehilite', # 高亮功能
'markdown.extensions.toc', # 将表单渲染为html, document类型
])
return render(request, 'test.html', {'markdown_str_text': md5_content })
3.查看效果
如果不加safe,就是将字符串传过来,如果加了safe,就是原样给
4. 优化:
有时候原md文档中,``````的脚本渲染不出来,如下,这个脚本是没有渲染出来
就可以在view中,对md文档进行处理,如以上情况的处理方式是 把 文档分成每一行,
1.如果是```的行
2. 就把首尾的两个空格去掉,
3.然后再把 回车符号加上,还原
content = ""
for line in old_content.split("\n"):
content += line.strip(" ") if "```" in line else line
content +="\n"
这样把对 原md文档处理了,就渲染新的content。