后端传给前端的HTML字符串并不能显示为HTML格式,而是显示成字符串格式.
例如:
page_str = """
<a href="/app01/userlist/?p=1">1</a>
<a href="/app01/userlist/?p=2">2</a>
<a href="/app01/userlist/?p=3">3</a>
"""
return render(request,'user_list.html',{'page_str':page_str})
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>user_list</title>
</head>
<body>
<div>
{{ page_str }}
</div>
</body>
</html>
这样给前端传入一个page_str字符串后,在页面显示如下:
并不能解析成HTML格式.这是因为浏览器默认后台传过来的字符串都是不合法的.
要想让字符串合法有如下两种方式:
方法一:在前端设置
在前端接收字符串的时候加入一个filter:sfe:
{{ page_str | safe }}
方法二:在后端设置
导入mark_safe模块:
from django.utils.safestring import mark_safe
page_str = """
<a href="/app01/userlist/?p=1">1</a>
<a href="/app01/userlist/?p=2">2</a>
<a href="/app01/userlist/?p=3">3</a>
"""
page_str = mark_safe(page_str)
return render(request,'user_list.html',{'page_str':page_str})
用这两种方法其中的一种,在页面显示就如下所示:
写在最后
本文是个人的一些学习笔记,如有侵权,请及时联系我进行删除,谢谢大家.