浅谈网站机能之前端机能优化

近来项目逐步走上正轨,需求趋于平稳,这才想起须要对整站举行机能优化。经由一段时刻的进修,连系如今项目标现实机能状况,发明确切有许多地方能够举行优化。于是就最先了我的前端机能优化之旅。以下内容仅为个人明白,假如本内容人人以为那里写的不对,望人人指出,供一同议论。

浅谈网站机能之前端机能优化

机能优化的目标无非是削减用户流量斲丧,提拔用户首屏体验,提拔用户接见速率,让用户专注内容自身。

前端机能优化

  1. 削减 HTTP 要求数目

    • 基本道理:在浏览器与服务器举行通讯时,主如果经由过程 HTTP 举行通讯。浏览器与服务器须要经由三次握手,每次握手须要消费大批时刻。而且差别浏览器对资本文件并发要求数目有限(差别浏览器许可并发数),一旦 HTTP 要求数目到达肯定数目,资本要求就存在守候状况,这是很致命的,因而削减 HTTP 的要求数目能够很大程度上对网站机能举行优化。

      1. CSS Sprites:国内俗称 CSS 精灵,这是将多张图片兼并成一张图片到达削减 HTTP 要求的一种解决计划,能够经由过程 CSS background 属性来接见图片内容。这类计划同时还能够削减图片总字节数,节约定名词汇量(由定名多张图片文件变成一张,哈哈哈)。

      2. 兼并 CSS 和 JS 文件:如今前端有许多工程化打包东西,如:grunt、gulp、webpack等。为了削减 HTTP 要求数目,能够经由过程这些东西再宣布前将多个 CSS 或许 多个 JS 兼并成一个文件。

      3. 采纳 lazyLoad:俗称懒加载,能够掌握网页上的内容在一最先无需加载,不须要发要求,比及用户操纵真正须要的时刻马上加载出内容。如许就掌握了网页资本一次性要求数目。

  2. 掌握资本文件加载优先级

    • 基本道理:说到这里就须要晓得浏览器加载 HTML 内容的道理,浏览器在加载 HTML 内容时,是将 HTML 内容从上至下顺次剖析,剖析到 link 或许 script 标签就会加载 href 或许 src 对应链接内容,为了第一时刻展现页面给用户,就须要将 CSS 提早加载,不要受 JS 加载影响。

      1. 遵循原则:重要文件放在 head 内部,次要文件放在 body 底部。平常状况下都是 CSS 在头部,JS 在底部。

  3. 应用浏览器缓存

    • 基本道理:浏览器缓存分强缓存和协商缓存,他们是将收集资本存储在当地,守候下次要求该资本时,假如掷中就不须要到服务器从新要求该资本,直接在当地读取该资本。

      1. 强缓存:在 web 服务器返回的相应中增添 Expires 和 Cache-Control Header。

      2. 协商缓存:经由过程【Last-Modified,If-Modified-Since】和【ETag、If-None-Match】这两对 Header 离别治理。

  4. 运用 CDN

  5. 削减重排(Reflow)

    • 基本道理:重排是 DOM 的变化影响到了元素的多少属性(宽和高),浏览器会从新盘算元素的多少属性,会使衬着树中受到影响的部份失效,浏览器会考证 DOM 树上的一切别的结点的 visibility 属性,这也是 Reflow 低效的缘由。假如 Reflow 的过于频仍,CPU 运用率就会急剧上升。

      1. 削减 Reflow,假如须要在 DOM 操纵时增添款式,只管运用 增添 class 属性,而不是经由过程 style 操纵款式。

  6. 削减 DOM 操纵

  7. 图标运用 IconFont 替代

花絮

在最先提笔写这篇博客前就遇到了一个很辣手的题目,这篇博客题目叫什么,思索了一会,我内心冒出了三个答案:

  1. 浅谈网站机能优化

    • 第一个题目网站机能优化,一看题目能够明白为是讲网站机能,而且是对网站举行优化,形貌的是一种解决计划,但是网站机能包含的太多了,超出了我的学问领域,所以摒弃。

  2. 浅谈网站机能之前端机能优化

    • 第二个题目正适我怀,答题归纳综合了我本期博客内容,既有机能引见,又有前端机能优化解决计划。

  3. 浅谈前端机能优化

    • 第三个题目前端机能优化,心想这不就是我要写的内容嘛,等我写完内容发明,不对,我写的内容不仅仅是解决计划,好包含的其他内容,所以摒弃。

以上内容仅为个人明白,假如本内容人人以为那里写的不对,望人人指出,供一同议论,点击此处更多文章

    原文作者:acrens
    原文地址: https://segmentfault.com/a/1190000006922364
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞