JS 三种添加元素的方式、区别( write、createElement、innerHTML )

文章目录

  • [1. 区别结论](#1. 区别结论)
  • [2. write 不同场合的效果](#2. write 不同场合的效果)
  • [3. createElement 和 innerHTML 耗时对比](#3. createElement 和 innerHTML 耗时对比)

1. 区别结论

方式 说明
document.write 不建议使用, 使用时要小心, 不同场合, 效果不同
document.createElement 添加少量元素时建议使用, 结构清晰易读
innerHTML 添加大量元素时建议使用

2. write 不同场合的效果

① 正常文档流中使用,会在原文档流内追加元素。
② 回调函数中使用,会按照 document.write 的内容重绘画面, 之前文档流内容会被覆盖。

正常文档流中使用:

回调函数中使用:

3. createElement 和 innerHTML 耗时对比

1. 添加少量元素时的耗时对比:
我自己试几次 createElement 能稍快一点, 但是因为数据量小, 所以差距可以忽略不记, 差距不大的情况下, 我建议使用 createElement, 因为更易读、更灵活。

2. 当插入的元素非常多时, 两者区别还是比较明显的, 下面为实验代码:

① document.createElement 耗时实验代码:

html 复制代码
<!doctype html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>页面添加元素</title>
</head>
<body>
<script>
  window.addEventListener('load', () => {

    let body = document.body
    let start = new Date()

    for (let i = 0; i < 10000; i++) {
      let ele = document.createElement("div")
      ele.style.width = '10px'
      ele.style.height = '10px'
      ele.style.border = '1px solid black'
      body.appendChild(ele)
    }
    console.log(`总耗时:${new Date() - start} 毫秒`)
  })
</script>
</body>
</html>

② ele.innerHTML 耗时实验代码:

html 复制代码
<!doctype html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>页面添加元素</title>
</head>
<body>
<script>
  window.addEventListener('load', () => {

    let ele = []
    let body = document.body
    let start = new Date()

    for (let i = 0; i < 10000; i++) {
      ele.push('<div style="width:10px; height:1px; border:1px solid black;"></div>')
    }
    body.innerHTML = ele.join('')
    console.log(`总耗时:${new Date() - start} 毫秒`)
  })
</script>
</body>
</html>

(3) 上面两段代码, 我分别执行了 5 次:

innerHTML 平均耗时为 18.6 毫秒

createElement 平均耗时为 56 毫秒

结论就是, 当添加很多元素时, 首选 数组 + innerHTML 的方式

相关推荐
薛定猫AI17 分钟前
【深度解析】从 Antigravity 更新看 Agent IDE 的工程化演进:权限、沙盒、MCP 与模型治理
前端·javascript·ide
漂流瓶jz7 小时前
总结CSS组件化演进之路:命名规范/CSS Modules/CSS in JS/原子化CSS
前端·javascript·css
steven~~~8 小时前
为什么mq报错
javascript
threelab9 小时前
Three.js 初中数学函数可视化 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器
凉辰10 小时前
解决 H5 键盘遮挡与页面上推
开发语言·javascript·计算机外设
zz58812 小时前
面试官问"JS的类型"时,到底想听到什么?
javascript
gjwjuejin12 小时前
全埋点技术方案深度剖析:从事件代理到无痕采集的完整实现
javascript
前端若水13 小时前
在 Vue 2 与 Vue 3 中使用 markdown-it-vue 渲染 Markdown 和数学公式
前端·javascript·vue.js
之歆13 小时前
DAY_10 JavaScript 深度解析:原型链 · 引用类型 · 内置对象 · 数组方法全攻略(下)
开发语言·前端·javascript·ecmascript
__log14 小时前
ComfyUI 集成技术方案分析报告
javascript·python·django