前端性能优化方法

前端性能优化

一、请求响应优化

  1. 减少DNS查找:每次主机名的解析都需要一次网络往返,从而增加了请求的延迟时间同时还会阻塞后续的请求。
  2. 重用TCP连接:尽可能的使用持久连接,以消除因TCP握手和慢启动导致的延迟。
  3. 减少HTTP重定向:HTTP冲定向需要额外的DNS查询、TCP握手等非常耗时,最佳的重定向次数为0。
  4. 压缩传输的资源:比如Gzip、图片压缩。
  5. 便用缓存:比如HTTP 缓存、CDN缓存、Service Worker 缓存。
  6. 使用 CDN(内容分发网络):把数据放在离用户地理位置更近的地方,可以明显减少每次TCP连接的网络延迟,增大吞吐量。
  7. 删除没有必要请求的资源。
  8. 在客户端缓存资源:缓存必要的应用资源,避免每次都重复请求相同的内容,例如多图片下载可以考虑使用缓存。
  9. 内容在传输前先压缩:传输数据之前应该先压缩应用资源,把要传输的字节减少到最小在压缩的时候确保对每种不同的资源采用最好的压缩手段。
  10. 消除不必要的请求开销:减少请求的HTTP首部数据(比如 HTTP COokie)
  11. 并行处理请求和响应:请求和响应的排队都会导致延迟,可以尝试并行的处理请求和响应(利用多个HTTP11连接实现并行下载,在可能的情况下使用HTTP管道计数)。12针对协议版本采取优化措施。升级到HTTP2.0。
  12. 根据需要采用服务端渲染方式。这种方式可以解决SPA应用首屏渲染慢的问题。
  13. 采用预渲染的方式快速加载静态页面。页面渲染的极致性能,比较适合静态页面。
1、DNS优化
  1. 减少DNS的请求次数
  2. 进行DNS预获取:DNS Prefetch
2、HTTP压缩传输的数据源
  1. 响应数据:使用Gzip压缩文本
  2. 请求数据:
    请求体:HTTP协议中的Accept-Encoding/Content-Encoding机制。这套机制可以很好地用于文本类响应正文的压缩
    请求头:HTTP/2 引入了头信息压缩机制(header compression)
3、强缓存和协商缓存
  1. 强缓存
  2. 协商缓存
4、CDN缓存
  1. 避免对静态资源的请求携带不必要的Cookie信息
  2. 考虑浏览器对同一域名下并发请求的限制。

二、渲染优化

  1. JavaScript处理:前端项目中经常会需要响应用户操作,通过JavaScript对数据集进行计算、操作DOM元素,并展示动画等视觉效果。当然对于动画的实现,除了 JavaScript,也可以考虑使用如CSSAnimations、Transitions等技术。
  2. 计算样式:在解析CSS文件后,浏览器需要根据各种选择器去匹配所要应用CSS规则的元素节点,然后计算出每个元素的最终样式。
  3. 页面布局:指的是浏览器在计算完成样式后,会对每个元素尺寸大小和屏幕位置进行计算。由于每个元素都可能会受到其他元素的影响,并且位于DOM树形结构中的子节点元素,总会受到父级元素修改的影响,所以页面布局的计算会经常发生。
  4. 绘制:在页面布局确定后,接下来便可以绘制元素的可视内容,包括颜色、边框、阴影及文本和图像。
  5. 合成:通常由于页面中的不同部分可能被绘制在多个图层上,所以在绘制完成后需要将多个图层按照正确的顺序在屏幕上合成,以便最终正确地渲染出来。
1、 优化DOM

HTML文件的尺寸应该尽可能的小,目的是为了让客户端尽可能早的接收到完整的 HTML。总结起来有三种方式可以优化HTML:

  1. 缩小文件的尺寸(Minify)
  2. 使用gzip压缩 Tiar (Compress)
  3. 使用缓存(HTTP Cache)。
2、 优化CSSOM
  1. 让这些非关键的 CSS 资源不阻塞渲染。
<!--阻塞渲染-->
<link href="style.css" rel="stylesheet">

<!-- 非阻塞的加载Css--->
<link href="print.css" rel="stylesheet" media="print">

<!-- 拆分媒体查询相关CSS 资源:可变阻塞加载 -->
<link href="other.css" rel="stylesheet" media="(min-width: 40em)">

<!-- 具有动态媒体查询,将在网页加载时计算 -->
<link href="portrait.css" rel="stylesheet" media="orientation:portrait">
  1. 将关键CSS直接内联到HTML文档内。
  2. 避免在CSS中使用@import
3、 优化 JavaScript的使用
  1. 异步加载JavaScript,避免同步请求;延迟解析JavaScript;避免运行时间长的JavaScript:使用differ延迟加载
  2. 使用CSS实现动画效果
  3. 恰当使用WebWorker

可将一些纯计算的工作迁移到WebWorker上处理,它为JavaScript的执行提供了多线程环境,主线程通过创建出Worker子线程,可以分担一部分自己的任务执行压力。在 Worker子线程上执行的任务不会干扰主线程,待其上的任务执行完成后,会把结果返回给主线程,这样的好处是让主线程可以更专注地处理UI交互,保证页面的使用体验流程。

  1. 函数防抖和节流
4、 计算样式优化
  1. 减少要计算样式的元素数量:使用类选择器代替标签选择器、避免使用通配符做选择器
  2. 降低选择器的复杂性
  3. 使用BEM规范:.block__element--modifier
5、 避免触发页面布局与重绘
  1. 避免样式频繁改动
  2. 使用类名对样式进行修改
  3. 缓存对敏感属性值的计算
  4. 使用requestAnimationFrame方法控制渲染帧

JS性能优化

目的

  • 首屏时间
  • 首次交互时间
  • 首次有意义内容渲染时间

页面性能检测

  • https://developers.googLe.com/speed/pagespeed/insights/

方法

  1. 只请求当前需要的资源:
  • 异步加载
  • 懒加载
  • 按需加载:优化polyfill(针对低版本浏览器的转义)https://polyfill.io/v3/url-builder/
  1. 缩减资源体积:
  • 打包压缩(webpack4已内置、gzip)
  • 图片格式优化:(https://tinypng.com/)、根据屏幕动态适配图片分辨率、webp无损压缩
  • 控制cookie大小(request header),同域名请求携会带所有cookie
  1. 时序优化:
  • promise.all
  • ssr (而且还方便seo)
  • prerender prefetch preload
<!-- 让文件会立马解析DNS(DNS预解析) -->
<link rel="dns-prefetch" href=''>
<!-- 预加载 -->
<link rel="dns-preload" as="image" href=''>
<!-- 预链接 -->
<link rel="dns-preconnect" href=''>
  1. 合理利用缓存:
  • cdn预热和刷新

通过刷新功能,您可以强制CDN节点回源并获取最新文件;通过预热功能您可以在业务高峰期预热热门资源,提高资源访问效率。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,254评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,875评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,682评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,896评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,015评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,152评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,208评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,962评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,388评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,700评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,867评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,551评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,186评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,901评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,689评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,757评论 2 351

推荐阅读更多精彩内容

  • 什么是前端性能优化(what)? 从用户访问资源到资源完整的展现在用户面前的过程中,通过技术手段和优化策略,缩短每...
    我性本傲阅读 3,498评论 0 3
  • 日常工作和生活中,我们经常利用浏览器去打开一些URL来获取我们所需的资源,那么作为一个开发者或者性能测试工程师,如...
    七月鎏金阅读 723评论 0 0
  • 性能在前端一直是容易被忽略的点,但是却又是非常重要的部分。 HTML 1. 压缩HTML:将注释、空格和新行从生产...
    追风的云月阅读 547评论 0 0
  • 网络请求 减少HTTP资源请求次数(合并接口) 减小HTTP请求大小 避免页面中空的href和src 减少页面重定...
    xiaolizhenzhen阅读 452评论 0 0
  • 网络请求 减少HTTP资源请求次数(合并接口) 减小HTTP请求大小 避免页面中空的href和src 减少页面重定...
    Artifacts阅读 254评论 0 0