web前端性能优化——如何提高页面加载速度

2019-01-13  本文已影响0人  阿小经

什么叫web前端性能优化?

  • 使用户觉得页面加载快!
  • 使用户觉得页面加载快!
  • 使用户觉得页面加载快!

重要的话说三遍!!!

(接下来总结下前端提高页面加载速度的一些方法。)

前端性能优化

思路:分析一个页面从输入 URL 到页面加载显示完成的所有步骤,采用分治法逐步优化。

1.优化DNS查询

减少域名:尽量把所有的资源放在一个域名下。一个域名同时可以发4(IE8)或8个请求(Chrome)。请求文件少,用1个域名,文件多用多个域名。与3权衡。

2.优化TCP协议

3. 优化发送HTTP请求

4.优化接受响应

5.优化DOCTYPE

6.优化CSS、JS请求

7.使用懒加载

const xxx =()=>import('./components/xxx.vue')

8.优化用户体验

9.减少监听器,使用事件委托

    <body>
        <ul>
            <li>1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
        </ul>
        <script>
            let liList = document.querySelectorAll('li')

            // liList[0].onclick = ()=>console.log(1)
            // liList[1].onclick = ()=>console.log(2)
            // liList[2].onclick = ()=>console.log(3)
            // liList[3].onclick = ()=>console.log(4)
            //法一:监听太多

            let ul = document.querySelector('ul')

            ul.onclick = (e) => {
                if (e.target.tagName === 'LI') {
                    console.log(e.target.innerText)

                }
            }//法二:减少监听,采用事件委托
        </script>
    </body>

10.优化图片大小

11.减少或合并DOM操作或使用虚拟DOM

// 不好的方式
var elem = $('#elem');
for (var i = 0; i < 100; i++) {
 elem.append('<li>element '+i+'</li>');
}

// 好的方式
var elem = $('#elem' ),
arr = [];
for (var i = 0;  i < 100; i++) {
  arr.push('<li>element ' +i+'</li>' );
}
elem.append(arr. join(''));

12.对大量数据计算使用缓存

// data.length === 100000
   for(var i = 0;i < data.length;i++){
     // do something...
   }
   //上面的代码没有下面的好
   for(var i = 0,len = data.length;i < len;i++){
     // do something...
   }

13.使用setTimeout降低调用接口频率

参考文章: 雅虎前端优化的35条军规

上一篇下一篇

猜你喜欢

热点阅读