innerHTML + bypassSecurityTrustHtml 导致节点重复渲染(innerHTML 中有多个函数时的执行顺序问题)

博客围绕[innerHTML]和DomSanitizer的bypassSecurityTrustHtml()搭配使用导致节点无限重复渲染的问题展开。分析了可能原因,一是bypassSecurityTrustHtml()接收参数时render方法可能后执行,二是innerHTML接收函数而非转换完成的html代码。最终利用管道进行html代码安全处理,严格控制函数执行顺序解决问题。

目录

1.问题

2.思考

2.1 何谓 DomSanitizer?何谓 bypassSecurityTrustHtml()?

2.2 回到问题本身进行分析

3.解决


1.问题

[innerHTML] 和 DomSanitizer 的 bypassSecurityTrustHtml() 搭配使用,导致节点无限重复渲染

// 产生 html代码
render: (row) => {
    return `<div> ${row.rankNum) </div>`;
)

// 获取安全 Html代码
getSafeHtml(html): SafeHtml {
    return this.sanitizer.bypassSecurityTrustHtml(html);
}

// html 里使用 innerHTML
<div class="header-td"
    [innerHTML]="getSafeHtml(render(row))">
</div>

2.思考

2.1 何谓 DomSanitizer?何谓 bypassSecurityTrustHtml()?

DomSanitizer:通过清理在不同 DOM上下文 中安全使用的值,来防止跨站点脚本安全漏洞(XSS)

bypassSecurityTrustHtml():是 DomSanitizer 下面的一个方法,通过接受 html代码svg图片,将他们转换为安全的值,防止出现报错

使用 innerHTML 的时候,可能会出现报错:WARNING: sanitizing HTML stripped some content (see http://g.co/ng/security#xss).

参考博客:Angular4 绑定html内容 警告处理_xiaotuni的专栏,每天进步一点点 -CSDN博客icon-default.png?t=M1L8https://blog.csdn.net/xiaotuni/article/details/77171240

2.2 回到问题本身进行分析

可能性一:

bypassSecurityTrustHtml() 接收的参数应该是 string

此处的 bypassSecurityTrustHtml() 接受了 render(row),render() 方法返回的是 string

重点来了:render() 这个方法 可能 在 bypassSecurityTrustHtml() 之后执行

就是说 render() 还没有返回数据,bypassSecurityTrustHtml() 直接接收了的 render() 这么个空方法

导致 render() 最终在 bypassSecurityTrustHtml() 内部运行,导致重复渲染

可能性二:

innerHTML 接收到的是 getSafeHtml(render(row)) 函数,而不是一段转换完成的 html代码,导致重复渲染

总结:

[innerHTML]、getSafeHtml()、render() 执行顺序不能确定,导致了重复渲染

3.解决

利用 管道 进行 html 代码安全处理,严格控制各个函数的执行顺序

// 产生 html代码
render: (row) => {
    return `<div> ${row.rankNum) </div>`;
)

// 通过定义管道,实现获取安全的 html代码 这个功能
transform(html: string): any {
    return this.sanitizer.bypassSecurityTrustHtml(html);
}

// html 里使用 innerHTML
<div class="header-td"
    [innerHTML]="render(row) | safeHtml">
</div>

执行顺序:

  • 先由 render(row) 生成 html代码
  • 再进入管道处理
  • 最后交由 [innerHTML] 插入节点

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Lyrelion

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值