关于JS优化

  1. DOM优化原则一:DOM和JS操作是分离的每一次操作都是要经过消耗的。要尽量减少这样的操作。 比如:将js全部操作完了再对DOM进行连接。
  2. 原则二:DOM操作innerHTML chrome耗能少 firefox,IE innerHTML 比 DOM耗能少
  3. 原则三:减少DOM的操作 。

解决办法

  1. 利用cloneNode(true) true代表克隆包括子节点 而不是每次都创建一个新的节点
  2. 尽量每次都用变量将DOM操作的值存储起来用做局部变量(只进行了一次的DOM操作)
    3.只获取元素节点,比如:childNodes 元素,文本节点 children元素节点
    4.querySelector,querySelectorAll 效率较高

    原则四:重排(改变页面内容)和重绘(浏览器显示页面内容)
    1.在appendChild()之前添加操作,这样就只会重绘一次
    2.合并DOM操作 cssText
    3.利用文档碎片信息 createDocumentFragment

 window.onload = function() {
        for (var i = 0; i < 5000; i++) {
                // document.innerHTML += 'a';
            }

            for (var i = 0; i < 5000; i++) {
                str += 'a';
            }
            document.innerHTML += str;

        **利用字符串累加,这样只会进行一次DOM操作,性能增加**

            for(var i=0;i<5000;i++){
                // var oLi = document.createElement('li');
                var newLi = oLi.cloneNode(true);

                利用克隆节点,而不是每次创建
            }

      每次保存len临时变量,而不是在循环中获取一次,在做其它操作的时候同理,不仅增加效率,而且可以简洁语义化。

            var len = aLi.length;
            for(var i=0;i<len;i++){
                aLi[i].innerHTML = 'li';
            }

    将所有的节点添加入Fragment中,最后在一次性加入父节点中、

            var oFrag = document.createDocumentFragment();
            for(var i=0;i<5000;i++){
                var oLi = document.createElement('li');
                oFrag.appendChild(oLi);
            }
            oUl.appendChild(oFrag);
        };
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值