首页 > 其他 > 详细

使用文档碎片减少DOM操作&事件代理

时间:2021-08-23 08:38:48      阅读:27      评论:0      收藏:0      [点我收藏+]
    <ul id="list"></ul>
      const ul = document.getElementById(‘list‘)
      const fragment = document.createDocumentFragment()
      for (let i = 0; i < 5; i++) {
        const li = document.createElement(‘li‘)
        li.innerHTML = `项目${i}`
        li.addEventListener(‘click‘, (e) => {
          e.stopPropagation()
          console.log(i)
        })
        // ul.appendChild(li) // 每次插入dom都会引起回流重绘
        fragment.appendChild(li) // 此时存于内存中,并没有操作dom
      }
      ul.appendChild(fragment) // 一次性插入dom,相比于每次创建li都插入dom节省性能
      // 事件代理
      ul.addEventListener(‘click‘, (e) => {
        if (e.target.nodeName !== ‘LI‘) return
        const arr = Array.from(ul.children)
        const index = arr.indexOf(e.target)
        const content = arr[index].innerHTML // e.target.innerHTML
        console.log(index)
        console.log(content)
      })

 

使用文档碎片减少DOM操作&事件代理

原文:https://www.cnblogs.com/wuqilang/p/15174014.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!