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

    <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)
      })
复制代码

 

posted @   吴小明-  阅读(36)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 提示词工程——AI应用必不可少的技术
· 字符编码:从基础到乱码解决
· 地球OL攻略 —— 某应届生求职总结
点击右上角即可分享
微信分享提示