标签:cli zip 最新 ali 划算 max-age 不必要 header 客户
前言,本文翻译自https://docs.google.com/presentation/d/1hBIb0CshY9DlM1fkxSLXVSW3Srg3CxaxAbdocI67NCQ/edit#slide=id.g32e52b1ea6_1_0看到之后感觉讲解的系统清晰明了,实属一篇好文。就加上自己的理解翻译了一下,聊以加深印象。
硬件(即处理能力)决定了计算密集型任务的表现
浏览器必须解析、编译并执行所有的js,如下如所示:
对于每个阶段而言,代码量的差异显然会影响其变现即影响性能,这种差异在低处理能力的机器上的体现尤为明显。
当然其他类型的资源请求也会影响性能,相比之下js的影响是比较突出的。
所以考虑不同用户cpu的状况,减少js怪物(即缩小js体积)是很必要的。可以从以下几方面着手:
借助相关工具
仅仅对需要ES5的客户端才进行转换,80%的浏览器已经支持ES2015。(结合自己实际开发情况,移动端而言确实80%+的手机已经支持ES2015,仅仅只遇到oppop,vivio这两中手机不支持。)因为转换之后的代价还是有的,如下所示:
//ES2015
books.map(b => b.title);
//ES5
books.map(function(b) { return b.title; }, this);
//体积大了一倍
像UglifyJS & Closure Compiler 之类的工具,在压缩之外还有一些优化功能。
对大多数的js而言压缩代码中空格移除和符号修改占了95%的工作量,并非是精心的代码转换。
压缩不应该是盲目的,应该平衡下面几点。
和压缩代码的目的一致,减小资源大小,不过是从另一个层面的解决方案。像webpack,rollup都提供了该功能。
tree-shaking会将没有被用到的exports移除
//tool
//used
export function a(){
console.log(‘1‘)
}
export function b(){
console.log(‘2‘)
}
//app.js
import {a} from ‘./tool‘
a()
function b 未被使用,最终的打包文件中b将会被删除。
import/export 在执行之前就被确定,并且两者只能在顶层,没有条件逻辑的情况下使用(毕竟未执行)
工具不能做到尽善尽美,并且在执行之前确定某项问题是困难的。
当前来说应该从代码规范和代码注释来自我完善。
如果非必须,请不要使用。大的框架至少300kb的体积。
当然必要,请基于下面几点来选择:
先看一下js不同引入方式的差别
默认方式 | Async | Defer | |
---|---|---|---|
阻塞渲染 | 是 | 否 | 否 |
执行时机 | 加载完成 | 加载完成 | document解析完成 |
整个应用只对应一个js
便于压缩
不利于缓存
粒度太大,即可维护性
忽然有种中庸的感觉了,凡事皆有度,所有单一操作都不能过分苛求极致,兼顾才是合理
当用户登录的时候加载余下的部分
将代价昂贵的库放到server端,使用ssr来代替client-side-render.
ssr可以将我们初始页面加载事件减少到原来的1/5并减少不同浏览器之间的差异。
ssr确实首屏的优化确实很大,优点不多说。但这里提一句,不要盲目ssr,特别是初次请求响应时间较长的接口
首先了解两个概念:
对于大部分市场来说,带宽是可以满足需求的(这里统计是国外的,平均26兆,国内略低一点),平均页面大小3.5Mb。传输时间(3.5/26)0.13s。国内会差一点。
延迟对性能影响比较明显。
移动网络的延迟
网络 | 延迟ms |
---|---|
5G | <=4 |
4G | <=100 |
3G | 100-500 |
3G | 300-1000 |
应该从下面几方面来分别考虑。
建立连接需要1至3+响应在数据相应之前。
TCP slow-start限制了在初始响应里里数据被发送的数量
请求的体积与相应时间并不是线性关系。
两次50k的请求消耗比一次100k的大了不少。
理想状态下,确实资源是否最新不应该通过网络请求
可以通过下面的方式:
这种浏览器调整为Facebook节省了60%的请求
service worker可以帮组我们:
使用HTTP2时,每个来源只需要一个连接,减少了连接创建的开销。
优化页面渲染或者加载时所需的事件以便尽可能的加快完成。
对于所有的请求,浏览器对其是有权重处理的,即分不同的优先级来加载。具体来说就是重要会阻塞渲染的优先级比较高。
如下图所示:
通过以下方式,提前加载或者请求将要用到的内容:
对于好的资源,多读收益还是很明显的。这次翻译感觉体会又多了一些,不过由于本人才疏学浅,如有错误还望多多指正。一言概之,共同学习。更多请移步
标签:cli zip 最新 ali 划算 max-age 不必要 header 客户
原文地址:https://www.cnblogs.com/pqjwyn/p/9002226.html