目录

当聊起前端性能优化我们要聊什么

背景

在前端的整个学习生涯中,我们总是能一次次听到“性能”和“体验”这两个词。前端性能优化不仅是前端工程师工作中时刻需要关注的现实问题,也是前端面试中屡屡被问到的点。面试官之所以爱问,是因为偷懒。只需问这一个问题,就能在一定程度考察面试者的知识广度、知识深度、总结能力、表达能力,还能沿着这条线继续问其他问题。

当被突然问到性能这个问题时,大部分人会突然一愣。总觉得有很多要说的东西,但又感觉杂乱无章一下子不知从何说起。经过一番思索,脑子里慢慢翻出早年面试刷题时看到的“雅虎性能优化N条军规”,抓耳挠腮说上七八条。面试官面无表情的问了句“还有吗?”,此刻又不得不把脑仁像挤海绵一样疯狂压榨,再多滴出两三条似是而非的油水。心里面满是苦恼,抱怨自己的记忆力不够好。

其实就算是全背下来一口气说个几十条,面试官也不见得多满意。原因之一是条目太多没有主次听着容易让人烦,面试官自己都记不住你说了什么。二是这种方式的回答明显给人一种死记硬背做题家的感觉。(面试官真欠抽)

我们要聊什么

回答性能问题有两个思路。顺着这两个思路,不需要过多记忆就能自然而然的并且“很有见地”的回答十几条甚至几十条优化方案,当然前提是这些优化方案你平时真的用过。

性能瓶颈主要出现在三个场景

  1. 在开发时每次修改代码打包需要几分钟,太慢(开发构建阶段
  2. 打开网站,等了几十秒才看到页面,太慢(资源加载页面渲染阶段)
  3. 页面展现后,页面上动画不流畅。滚动页面或者拖拽元素卡顿感严重,甚至页面会崩溃(操作体验阶段)

一、开发构建阶段(常见问题:如何让Webpack打包更快)

二、资源加载阶段

核心思路是:传输量要小、距离要近、并行传输、资源复用、预先加载。

传输量要小

距离要近

并行传输

资源复用

预先加载

三、页面渲染阶段

四、操作体验阶段

来自若愚\@饥人谷

思路二、从生活角度聊前端性能

假设你是公司的CTO,现在有一个产品需要在尽可能短的时间内上线,在现有团队不加班不996的前提下如何做?方案无外乎是:

  1. 压缩需求,迭代开发——压缩
  2. 多用旧轮子(代码、方案、架构)少造新轮子——缓存
  3. 增加人手——并发

和前端性能优化做对应

从以上两个思路入手,对于有经验的你来说自然才思泉涌,轻轻松松让自己和面试官兴奋起来,甚至能在一定程度上左右后续的提问。

提到性能,大脑里需要浮现6字箴言:压缩缓存并发。后面的都交给小脑自由发挥吧。

饥人谷一直致力于培养有灵魂的编程者,打造专业有爱的国内前端技术圈子。如造梦师一般帮助近千名不甘寂寞的追梦人把编程梦变为现实,他们以饥人谷为起点,足迹遍布包括facebook、阿里巴巴、百度、网易、京东、今日头条、大众美团、饿了么、ofo在内的国内外大小企业。 了解培训课程:加微信 xiedaimala03,官网:https://jirengu.com