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

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 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性能社区目前已经和前端早早聊社区建立战略合作,赋能更多前端开发者。

相关文章
我写了一个自动化脚本涨粉,从0阅读到接近100粉丝(二)
我写了一个自动化脚本涨粉,从0阅读到接近100粉丝
102 0
|
3月前
|
存储 前端开发 JavaScript
太爽了!这12个前端库,帮我在工作中赢得了不少摸鱼时间!!
太爽了!这12个前端库,帮我在工作中赢得了不少摸鱼时间!!
|
数据采集 Web App开发 JavaScript
我写了一个自动化脚本涨粉,从0阅读到接近100粉丝(一)
我写了一个自动化脚本涨粉,从0阅读到接近100粉丝
117 0
|
移动开发 监控 前端开发
作为一名前端工程师,说一说我眼里的用户增长
作为一名前端工程师,说一说我眼里的用户增长
242 0
作为一名前端工程师,说一说我眼里的用户增长
|
搜索推荐 SEO
新站SEO优化该从何入手
新站SEO优化该从何入手
112 0
新站SEO优化该从何入手
|
负载均衡 安全 搜索推荐
游戏陪玩源码并非越复杂越好,有时简单才是王道
游戏陪玩源码并非越复杂越好,有时简单才是王道
如何做好游戏陪玩源码的功能优化,这三步缺一不可
如何做好游戏陪玩源码的功能优化,这三步缺一不可
|
缓存 编解码 程序员
秃头程序员告诉你搭建直播平台要重点优化哪些地方
想要搭建直播平台,最先要搞清楚直播平台的开发目标是什么?一个直播平台有确立的开发目标是必须的。那么如何来确立?就是一定要想清楚,用哪种能来吸引住你的用户去使用你的直播APP?一起来看看来自秃头程序员的经验分享。
秃头程序员告诉你搭建直播平台要重点优化哪些地方
|
编解码 Unix Java
直播软件源码开发千万不能忘的一个知识点
对于直播软件源码开发的技术人员来讲,音视频即时通讯技术是需要熟练掌握的。毕竟像直播这样重视互动和实时性的应用场景,即时通讯可以从中起到很大的配合作用。目前市面上有很多服务商所提供的SDK可以帮助实现这一技术,但是在选择哪一家服务商时还需要多下一些功夫才行。本文主要分享一下开发过程中,音视频即时通讯会涉及哪些技术领域。
直播软件源码开发千万不能忘的一个知识点
|
数据可视化 前端开发 vr&ar
3D 真的很难吗,瞧瞧支付宝怎么做?
阿里妹导读:图像作为人类感知世界的视觉基础,是我们在这个信息化时代获取信息、表达信息及传递信息的重要手段,而生成图像最高效准确的方式就是由计算机生成、显示、绘制,这些技术又统称计算机图形技术。计算机图形技术已经是许多产业的技术基础,比如动画、影视特效、游戏、设计、广告、AR、VR、数据可视化等等。
5342 0