You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
86 lines
2.1 KiB
86 lines
2.1 KiB
= Pollyfill
|
|
市面上有很多浏览器,每种浏览器又有不同的版本,所支持的环境各不相同,为了抹平它们之间的差异,
|
|
于是出现了 Pollyfill 解决方案,Pollyfill 的作用是通过降级处理,
|
|
让新的语法能够运行在其不被支持的浏览器环境中,
|
|
常见的 Pollyfill 有 Babel、Autoprefixer 等。
|
|
|
|
以 Babel 为例,它是怎么判断项目是否需要做降级处理的呢,
|
|
答案就是通过 browserslist 查询出需要支持的浏览器列表,然后根据这个列表来做判断。
|
|
|
|
用 Babel 验证一下,先安装 Babel:
|
|
[source,bash]
|
|
----
|
|
# 在当前项目根目录中执行
|
|
npm install --save-dev @babel/core @babel/cli @babel/preset-env
|
|
----
|
|
|
|
创建 babel.config.json 文件,内容如下:
|
|
[source,bash]
|
|
----
|
|
{
|
|
"presets": ["@babel/preset-env"]
|
|
}
|
|
----
|
|
|
|
创建 .browserslistrc 文件,内容如下:
|
|
[source,bash]
|
|
----
|
|
chrome 96
|
|
----
|
|
|
|
创建 index.js 文件,内容如下:
|
|
[source,javascript]
|
|
----
|
|
const say = (msg) => {
|
|
console.log(msg)
|
|
}
|
|
say('hello')
|
|
----
|
|
|
|
运行 babel 编译命令
|
|
[source,bash]
|
|
----
|
|
./node_modules/.bin/babel index.js --out-dir lib
|
|
----
|
|
|
|
查看编译后的文件,发现并没有做降级处理,因为 chrome 96 本身就支持 const 和箭头函数.
|
|
[source,javascript]
|
|
----
|
|
"use strict";
|
|
|
|
const say = msg => {
|
|
console.log(msg);
|
|
};
|
|
|
|
say('hello');
|
|
----
|
|
|
|
修改 .browserslistrc 让其支持 ie9,内容如下:
|
|
[source,bash]
|
|
----
|
|
chrome 96
|
|
ie 9
|
|
----
|
|
|
|
运行编译命令后查看编译文件,发现已做降级处理.
|
|
[source,javascript]
|
|
----
|
|
"use strict";
|
|
|
|
var say = function say(msg) {
|
|
console.log(msg);
|
|
};
|
|
|
|
say('hello');
|
|
----
|
|
|
|
如果 .browserslistrc 包含版本较旧的浏览器,可能会增大打包文件的体积,
|
|
因为一些 api 需要通过 Pollyfill 来实现,比如某些浏览器不支持 Promise,
|
|
那么会在打包文件中注入 Promise 的补丁:
|
|
[source,javascript]
|
|
----
|
|
window.Promise = function () {}
|
|
----
|
|
|
|
而版本较新的浏览器本身就支持了 Promise,不需要打补丁。
|
|
所以可以根据项目的实际情况适当的设置 .browserslistrc 以减小打包文件的体积。
|