JS学习笔记之三种动态创建元素区别

最近在学习JavaScript的时候动态创建元素区别的内容将笔记分享给大家


前言

JS有三种方法来创建动态元素,分别是:
1.document.write()
2.innerHTML
3.document.createElement()


一、三种方法:

1.代码如下:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .inner {
            width: 200px;
            height: 200px;
            background-color: orange;
        }

        .create {
            width: 200px;
            height: 200px;
            background-color: skyblue;
        }
    </style>
</head>

<body>
    <button>按钮</button>
    <div>hahaha</div>
    <div class="inner"></div>
    <div class="create"></div>
    <script>
        // 三种创建元素方式区别
        // 1.document.write
        // 获取元素
        var btn = document.querySelector('button');
        // 注册事件
        btn.onclick = function () {
            document.write('<div>write添加的</div>');
        }
        // 2.innerHTML 创建元素
        var inner = document.querySelector('.inner');
        inner.innerHTML = '<a href="javascript:;">链接</a>';
        // 3.document.createElement()创建元素
        var create = document.querySelector('.create');
        var a = document.createElement('a');
        // 添加子节点
        create.appendChild(a);
    </script>

</body>

</html>

2.分析:

运行效果:
在这里插入图片描述
在这里插入图片描述

我们动态创建元素的方式有以上三种,我们可以看到三种方式都相应地创建了元素。
当我们点击按钮时会出现界面值剩下write添加的这个盒子,
为什么呢这是因为document.write 创建元素 如果页面文档流加载完毕,再调用这句话会导致页面重绘。
(重绘的意思就是页面给我们重新绘制了一个新的HTML页面)所以这种创建元素的方式不太好。
单个元素创建看不出另外两种方法的区别下面我们就通过多元素创建来讨论一下另外两种创建元素方式的区别。

二、innerHTML和document.createElement创建元素

1.代码如下:

innerHTML第一种方式:

//innerHTML拼接字符串方式
        function fn() {
            var d1 = +new Date();
            var str = '';
            for (var i = 0; i < 1000; i++) {
                // 通过拼接字符串方式循环创建盒子
                document.body.innerHTML += '<div style="width:10px;height:10px;border:1px solid skyblue;"></div>';
            }
            var d2 = +new Date();
            console.log('innerHTML拼接字符串方式耗时:'+ (d2 - d1) + '毫秒');
        }
        fn();

innerHTML第二种方式:

// innerHTML数组方式
function fn() {
            var d1 = +new Date();
            var arr = [];
            for (var i = 0; i < 1000; i++) {
                // 往数组里面添盒子
                arr.push('<div style="width:10px;height:10px;border:1px solid skyblue;"></div>');
            }
            // 把数组转换成字符串
            document.body.innerHTML = arr.join('');
            var d2 = +new Date();
            console.log('innerHTML数组方式耗时:' + (d2 - d1) + '毫秒');
        }
        fn();

createElement的方式:

//createElemen创建元素方式
function fn() {
            var d1 = +new Date();
            var str = '';
            for (var i = 0; i < 1000; i++) {
                // 创建新的元素再放到body里面去
                var div = document.createElement('div');
                div.style.width = '10px';
                div.style.height = '10px';
                div.style.border = '1px solid red';
                document.body.appendChild(div);
            }
            var d2 = +new Date();
            console.log('createElemen创建元素方式耗时:' + (d2 - d1) + '毫秒');
        }
        fn();

2.分析:

各对应运行结果:
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

innerHTML是将内容写入某个DOM节点,不会导致页面的重绘。
我们可以通过运行结果看到,innerHTML创建多个元素效率要更高一些,当然采用的是数组拼接方式而不
是字符串拼接方式,结构相应也复杂一些。而采用createElement的方式创建多个元素效率稍微低一点
但是结构比较清晰明了。

总结

以上就是今天要跟大家分享的三种动态创建元素区别的内容,并且说明不同浏览器下,innerHTML的效率要比creatElement高。
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值