【内有惊喜】聊一聊前端性能优化!

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 【内有惊喜】聊一聊前端性能优化!

前端是离用户最近的战场,而前端性能直接影响了用户体验。可以说,性能优化是初、中级工程师向高级工程师进阶的必学知识点,以及核心技能。


性能优化的商业价值


  • 对于mbify而言,主页加载的速度每提高100ms,转化率就会增加1.11%,平均年收入就会增加380000美元;
  • Pinterest重建了他们的页面以实现性能,使感知等待时间减少了40%,从而将搜索引擎流量和注册量提高了15%;
  • 通过将平均页面加载时间减少850毫秒,COOK发现他们能够将转化率提高7%,将跳出率降低7%,并将每个页面的页面数量增加10%;


可见前端性能优化对我们的影响和收入直接挂钩,高性能的网站比表现不佳的网站更好地吸引和留住用户。

1.jpg

“50%的用户会放弃访问加载超过3秒的网站”


如果高性能是一种资产,那么表现不佳就是一种负担。性能优化是一个项目发展到一定时期之后绕不开的话题,也是每个工程师心中永远在撩拨的刺,产品的好坏决定着客户的体验,那么一款产品的好坏有很多因素,其中性能是决定因素。


  • 当用户能够在 2 秒以内得到响应时,会感觉系统的响应很快;
  • 当用户在 2-5 秒之间得到响应时,会感觉系统的响应速度还可以;
  • 当用户在 5-8 秒以内得到响应时,会感觉系统的响应速度很慢,但是还可以接受;
  • 而当用户在超过 8 秒后仍然无法得到响应时,会感觉系统糟透了,或者认为系统已经失去响应,而选择离开这个 Web 站点,或者发起第二次请求。


一个网站的性能好坏是留住用户和实现变现的基础,也是我们前端工程师每天都要关注的问题。

2.jpg


两个方向全解前端性能优化


性能优化的点非常的多,有的小伙伴觉得记起来非常的麻烦,大家可以根据这两个方向来记忆:


  • 加载时优化:预加载、缓存、网络层、页面解析、静态资源、
  • 运行时优化:避免强制同步布局、长列表优化、避免js执行时间过长、并行计算-service worker、Composite分层绘制、滚动事件性能优化、Passive event listeners、动画

3.jpg


加载时优化


从用户体验上面来讲,如何让别人觉得你的网站性能不错,即使是一个这只是一个假象,那就是白屏时间和首屏时间:


  • 白屏时间是指浏览器从响应用户输入网址地址,到浏览器开始显示内容的时间。
  • 首屏时间是指浏览器从响应用户输入网络地址,到首屏内容渲染完成的时间。

4.jpg

5.jpg

  • 影响白屏时间的因素:网络,服务端性能,前端页面结构设计。
  • 影响首屏时间的因素:白屏时间,资源下载执行时间。


所以我们可以优先加载首屏资源,非首屏资源按需加载或懒加载,以加快首屏渲染速度。

我们可以从这个过程来挖掘优化点:交给DNS域名解析 -> 找到对应的IP地址 -> 然后进行TCP连接 -> 浏览器发送HTTP请求 -> 服务器接收请求 -> 服务器处理请求并返回HTTP报文 -> 以及浏览器接收并解析渲染页面通过缩短请求时间,从而去加快网站的访问速度,提升性能。


这个过程中可以提升性能的优化的点:


  • DNS解析优化,浏览器访问DNS的时间就可以缩短
  • 使用HTTP2
  • 减少HTTP请求数量
  • 减少http请求大小
  • 服务器端渲染
  • 静态资源使用CDN
  • 资源缓存,不重复加载相同的资源


运行时性能优化


另一方面我们可以从运行时的性能来优化,运行时性能是指页面运行时的性能表现,而不是页面加载时的性能。可以通过chrome开发者工具中的 Performance 面板来分析页面的运行时性能。


  • 减少重绘与重排
  • 避免页面卡顿
  • 长列表优化
  • 滚动事件性能优化
  • 使用 Web Workers
  • 写代码时的优化点


性能领域专家带你玩转前端性能优化


Donald Knuth 有一句名言:「过早优化乃万恶之源」。目前我们学习和解决前端性能优化问题,往往是在网上的一些教程,再或者就是看一些陈旧的教程文章,这样学来的知识不但不系统,而且没有很好的方法论总结。前端性能优化没有标准答案,想要面面俱到罗列出来,并非易事,它针对方方面面的资源都有不同的方式。


HeapDump性能社区是国内首个专注性能领域的垂直技术社区,十几万开发者在这里讨论和分享性能知识,作为性能领域最重要的一大板块——大前端性能性能优化,HeapDump性能社区目前已经和前端早早聊社区建立战略合作,赋能更多前端开发者。

相关文章
|
14天前
|
Web App开发 前端开发 JavaScript
前端开发必备神器大公开,用过的人都哭了:效率翻倍不是梦!
前端开发结合了创意与技术,本文介绍了几个提升开发效率的工具:Visual Studio Code、Webpack、Postman、GitHub 和 Chrome DevTools。这些工具分别在代码编辑、模块打包、API 测试、版本控制和网页调试等方面发挥重要作用,帮助开发者提高工作效率,优化项目管理。
24 4
|
4月前
|
存储 前端开发 JavaScript
太爽了!这12个前端库,帮我在工作中赢得了不少摸鱼时间!!
太爽了!这12个前端库,帮我在工作中赢得了不少摸鱼时间!!
|
SQL 存储 Oracle
平时做开发需要掌握哪些数据库方面的知识(个人经验之谈)
平时做开发需要掌握哪些数据库方面的知识(个人经验之谈)
238 0
|
Android开发 开发者
科普技术贴:个人开发者的那些赚钱方式
公众号:smart_android 作者:耿广龙|loonggg   移动互联网的火爆,衍生出了许多新兴的职业,比如:个人开发者,自媒体等等。还出现了许多所谓的互联网思维,反正就是带来了许多让人无法理解或者可以轻松赚钱的渠道。因为我是一名程序员,我今天就来谈谈个人开发者是如何来赚钱的。     其实最直接的方式无非就有两种,一种是接私活,一种是加广告。    
2434 0
|
移动开发 前端开发 JavaScript
前端资源分享-只为更好前端
前端资源分享-只为更好前端
1040 0
不起眼,但是足以让你收获的JVM内存案例
不起眼,但是足以让你收获的JVM内存案例
不起眼,但是足以让你收获的JVM内存案例
|
前端开发 算法 API
一道看似简单的阿里前端算法题
一道看似简单的阿里前端算法题
151 0
一道看似简单的阿里前端算法题
|
搜索推荐 API 开发者
让阅读有更多想象,Feedly 向所有开发者开放API
事实证明在Google Reader的关闭只会让整个RSS阅读市场和生态都更有活力。比如,最激进的Feedly自开放云平台、推出收费版本后,再一次有了一个重大举动:向所有开发者开放自己的API。这意味着它不仅要把自己打造成最好的阅读器工具,还要完成Google Reader未竟的事业:让自己成为一个平台,并搭建生态系统。
620 0
让阅读有更多想象,Feedly 向所有开发者开放API
|
数据采集 小程序 搜索推荐
吐血整理!程序员常见的几种变现方式!
吐血整理!程序员常见的几种变现方式!
如何做好游戏陪玩源码的功能优化,这三步缺一不可
如何做好游戏陪玩源码的功能优化,这三步缺一不可
下一篇
无影云桌面