前端创建元素的四种方式

**document.write

  1. html代码
    <button>点击</button>
  2. js代码
// 1. document.write() 创建元素  如果页面文档流加载完毕,再调用这句话会导致页面重绘
        var btn = document.querySelector('button');
        btn.onclick = function() {
            document.write('<div>123</div>');
        }

**2 innerHTML创建元素

  1. innerHTML拼接型
<script>
    function fn() {
        var d1 = +new Date();

        var str = '';
        for (var i = 0; i < 1000; i++) {
            document.body.innerHTML += '<div style="width:100px; height:2px; border:1px solid blue;"></div>';
        }
        var d2 = +new Date();
        console.log(d2 - d1);
    }
    fn();
</script>
  • innerHTML数组型
<script>
    function fn() {
        var d1 = +new Date();
        var array = [];
        for (var i = 0; i < 1000; i++) {
            array.push('<div style="width:100px; height:2px; border:1px solid blue;"></div>');
        }
        document.body.innerHTML = array.join('');
        var d2 = +new Date();
        console.log(d2 - d1);
    }
    fn();
</script>

3 document.createElement()创建元素

<script>
    function fn() {
        var d1 = +new Date();

        for (var i = 0; i < 1000; i++) {
            var div = document.createElement('div');
            div.style.width = '100px';
            div.style.height = '2px';
            div.style.border = '1px solid red';
            document.body.appendChild(div);
        }
        var d2 = +new Date();
        console.log(d2 - d1);
    }
    fn();
</script>

4 document.createDocumentFragment();****

 //使用了createDocumentFragment()的程序
    var d3 = new Date();
    var pFragment = document.createDocumentFragment();
    for(var i = 0 ; i < 1000; i ++) {
       		var div = document.createElement("div");
      		div.style.width = '100px';
            div.style.height = '2px';
            div.style.border = '1px solid red';
       		pFragment.appendChild(div);
    }
    document.body.appendChild(pFragment);
    var d4 = new Date();
    document.write("第2次创建需要的时间:"+(d4.getTime()-d3.getTime()));

这四种创建元素,

  • createDocumentFragment()速度最快
  • 数组的innerHTML次之
  • createElement第三,
  • 字符串的innerH第四
  • document.write()最慢
发布了17 篇原创文章 · 获赞 0 · 访问量 424

猜你喜欢

转载自blog.csdn.net/weixin_44805161/article/details/102612837