使用文档碎片减少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) })
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 提示词工程——AI应用必不可少的技术
· 字符编码:从基础到乱码解决
· 地球OL攻略 —— 某应届生求职总结