Iwen's blog Iwen's blog
首页
  • 前端文章

    • JavaScript
    • Vue
  • 学习笔记

    • 《JavaScript教程》笔记
    • 《JavaScript高级程序设计》笔记
    • 《ES6 教程》笔记
    • 《Vue》笔记
    • 《TypeScript 从零实现 axios》
    • 小程序笔记
  • HTML
  • CSS
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • Linux
  • 学习
  • 面试
  • 心情杂货
  • 友情链接
  • 网站
  • 资源
  • Vue资源
  • 分类
  • 标签
  • 归档
复盘
关于

Iwen

不摸鱼的哥哥
首页
  • 前端文章

    • JavaScript
    • Vue
  • 学习笔记

    • 《JavaScript教程》笔记
    • 《JavaScript高级程序设计》笔记
    • 《ES6 教程》笔记
    • 《Vue》笔记
    • 《TypeScript 从零实现 axios》
    • 小程序笔记
  • HTML
  • CSS
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • Linux
  • 学习
  • 面试
  • 心情杂货
  • 友情链接
  • 网站
  • 资源
  • Vue资源
  • 分类
  • 标签
  • 归档
复盘
关于
  • Vue

  • Vue进阶

  • CSS

  • ES6

  • Base

  • Core

  • Array

  • Object

  • String

  • Async

  • Browser

  • Http

  • 性能优化

    • 节流防抖
    • 图片懒加载
    • Script的加载和执行
    • 防抖多列表的骚操作
    • 渲染几万条数据不卡住页面
    • 前端性能优化总结
  • 正则

  • 经典总结

  • 设计模式

  • 数据结构

  • 算法

  • 手写

  • TypeScript

  • 复盘
  • 性能优化
Mr.w
2020-11-29

渲染几万条数据不卡住页面

# 渲染几万条数据不卡住页面

常见的面试题,也是大型项目必备的优化知识点

const oUl = document.querySelector('ul')
for (let i = 0; i < 200000; i++) {
    const oLi = document.createElement('li')
    oLi.innerHTML = i;
    oUl.appendChild(oLi)
}
1
2
3
4
5
6

使用for循环一个一个插入的话,每次都会进行操作DOM...此处省略八千字,具体参考vue源码

解决办法:创建文档片段Fragment,将标签全部放入该片段中,再统一插入document,这样只会渲染一次,只会操作一次DOM

console.time('over')

let oUl = document.querySelector('ul')
let fragment = document.createDocumentFragment()

for (let i = 0; i < 200000; i++) {
    const oLi = document.createElement('li')
    oLi.innerHTML = i;
    fragment.appendChild(oLi)
}

oUl.appendChild(fragment)

// 据说下面这样子世界会更清净
fragment = null

console.timeEnd('over')
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
防抖多列表的骚操作
前端性能优化总结

← 防抖多列表的骚操作 前端性能优化总结→

最近更新
01
flex布局页面自适应滚动条问题
12-28
02
前后端分离开发请求接口跨域如何携带cookie的问题
12-28
03
怎么实现div长宽比固定width-height4比3
12-28
更多文章>
Theme by Vdoing | Copyright © 2017-2022 Iwen | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式