booktest23-html转义

本文详细介绍了在Django框架中如何处理HTML内容的转义问题,包括使用safe过滤器和autoescape标签来关闭默认的转义功能,确保动态生成的HTML代码能够正确显示为预期的网页元素。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1添加视图函数

def html_escape(request):
    return render(request,'booktest/html_escape.html',{'content':'<h1>hello</h1>'})

2.新建视图模板

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    {{content}}
</body>
</html>

3.url

url(r'^html_escape$', views.html_escape),

4,访问

5.网页源代码,被转义了,没有显示成h1标签

6.关闭转义,第一种方法:使用safe过滤器,修改html代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    {{content|safe}}
</body>
</html>

第二种方法使用autoescape标签

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
#on打开转义,off关闭转义<br/>
{% autoescape on%}
    {{content}}
{% endautoescape%}
#硬编码默认不会转义
{{test|default:'<h1>hello</h1>'}}

</body>
</html>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值