python Django学习(11)——字符串不合法

    后端传给前端的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})

用这两种方法其中的一种,在页面显示就如下所示:
在这里插入图片描述

写在最后

    本文是个人的一些学习笔记,如有侵权,请及时联系我进行删除,谢谢大家.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值