动态添加DOM元素的方式

应用场景

由于频繁操作DOM会占用较多的内存资源,为了减少内存的消耗,就要尽可能少地操作DOM。但是有需要动态添加,我们可以成批次的添加,就是将多个要添加的DOM元素先放在一起,然后一次性的添加上去

docuemnt.createDocumentFragment()

该方法可以生成一个文档片段,并且该文档片段也可以添加子元素,当该文档片段添加到页面上时本身并不会被添加到页面上,相当于一个虚拟的父元素,只是一个容器
如果我们要添加多个DOM元素时,可以先创建一个文档片段

var frag = document.createDocumentFragment();

此时已经创建了一个文档片段
再创建一个要添加到页面上的元素

var oP = document.createElement("p");
//设置元素内容
oP.innerText="hello world";

此时已经创建了一个p元素
再将要添加的元素添加到文档片段上

frag.appendChild(oP);

此时已经将p元素添加到文档片段上了
再将文档片段添加到页面上

document.body.appendChild(frag);

此时p元素就添加到页面上了
在这里插入图片描述

由于只是添加一个元素对浏览器的负担没有那么重,但是当需要添加多个元素时此种方法就可以有效的减少操作DOM的次数

element.innerHTML

这种方法也可以一次性添加多个元素到页面上,利用元素的innerHTML属性可以将要添加的元素拼接成字符串然后在一次性添加到页面上
先创建一个变量用来存储拼接的字符串

var str= `<p>hello world</p>`;

在将字符串赋值给body

document.body.innerHTML=str;

此时p元素已经添加到页面上了
在这里插入图片描述
这种方法比之前的方法更加简单,不需要多次调用创建元素的方法,只需要用字符串就行

document.write()

这种方法也可以添加元素,只不过该函数会将页面上原有的元素覆盖,所以这种方法不常用只有需要替换页面上的元素的时候可以使用
先创建一个变量存储要添加的元素

var str="<p>hello</p>";

在调用document.write()方法

document.write(str);

此时元素已经添加到页面上了
在这里插入图片描述
前面已经讲了该方法会覆盖页面上的元素,在使用时视需求而定

总结

  1. 这几种方法都可以动态添加DOM元素,各有优劣,视需求而定
  2. 第一种和第二种方法还可以在一定程度上减少操作DOM的次数,第三种方法不会减少操作DOM的次数,并且会覆盖页面上原有的元素
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
在Vue中,可以使用createElement函数动态创建DOM元素。createElement函数接受三个参数,分别是标签名、属性对象和子元素。通过调用createElement函数,可以创建一个虚拟节点(vnode),然后将其插入到父元素中。 例如,如果要创建一个div标签,并给其添加元素,可以使用以下代码: ```javascript render(createElement) { return createElement('div', {}, \[ createElement('p', {}, '这是一个段落'), createElement('span', {}, '这是一个span元素') \]) } ``` 在上述代码中,createElement('div', {}, \[...\])创建了一个div标签,并使用第三个参数添加了两个子元素p和span。 另外,如果想要创建组件节点,可以使用createComponent函数。在Vue的组件系统中,子组件的初始化创建是在createElm函数中进行的。 总结起来,Vue动态创建DOM元素可以通过createElement函数来实现,同时也可以使用createComponent函数来创建组件节点。 #### 引用[.reference_title] - *1* *3* [Vue.js源码解析-Vue初始化流程之动态创建DOM](https://blog.csdn.net/weixin_57699483/article/details/118994933)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Vue2笔记_01创建vdom并挂载到dom元素上](https://blog.csdn.net/qq_43260366/article/details/126908076)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端御书房

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值