js 对html string 做裁剪

需求:

  • 通过插件组装了一段html string 代码
  • 但是html 代码太过于长,导致页码很卡
  • 直接去解析html string 字符串很麻烦

进程:

  • 将html string 注入到网页,然后通过dom 的方式进行裁剪
  • js 可以通过createElement 来创建一个dom 来做容器,并把html 放到对应的容器里
    const div = document.createElement("div");
    const parsedHTML = document.createRange().createContextualFragment(htmlString)
    div.appendChild(parsedHTML)
  • 然后通过remove children 来进行裁剪
    let tableElement = div.children[1].children[0].children[1].children[0].children[0].children[0];
    while (tableElement.childElementCount > 20) {
        tableElement.removeChild(tableElement.lastChild)
    }
  •  然后再将dom 元素变成string 输出到需要的地方
    pathHtml = div.outerHTML;
  • html string 直接导入也可以使用  dangerouslySetInnerHTML 来做导入
    <div dangerouslySetInnerHTML={{__html: htmlString}}/>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值