前端开发那些事儿

认识Babel***

2021-02-05  本文已影响0人  loushumei

Babel是什么?
用于解析ES6,甚至比ES6更高级的语法,到ES5或ES4级别,满足浏览器的兼容性

环境搭建 & 基本配置

① package.json配置安装:

"devDependencies": {
  "@babel/cli": "^7.7.5",
  "@babel/core": "^7.7.5",
  "@babel/preset-env": "^7.7.5"
  "@babel/plugin-transform-runtime": "^7.7.5",
},
"dependencies": {
  "@babel/polyfill": "^7.7.0",
  "@babel/runtime": "^7.7.5"
}

.babelrc文件 配置:

{
    "presets": [
        [
            "@babel/preset-env", //es6+常用语法的解析
        ]
    ],
    "plugins": [
    ]
}

babel-polyfill 补丁

前置知识:

polyfill补丁:

polyfill是补丁,例如Array.IndexOf方法,根据浏览器的兼容情况,若不兼容,polyfill做一个补丁,使之兼容。

core-js 标准库:

core.js 是一个标准的库,集成了 ES6 ES7等所有新语法的polyfill(补丁),缺点是不支持regenerator的兼容性。

regenerator 运行时库:

这是 Facebook 提供的 facebook/regenerator 库,用来实现 ES6/ES7 中 generators、yield、async 及 await 等相关的 polyfills。

babel-polyfill是什么?
babel-polyfill 如何按需引入?

修改.babelrc文件的配置按需引入:

{
    "presets": [
        [
            "@babel/preset-env", //es6+常用语法的解析
      {
                "useBuiltIns": "usage",//按需引用
                "corejs": 3 //corejs版本
            }
        ]
    ],
    "plugins": [
    ]
}

babel-polyfill 的问题

污染全局环境

使用ES6的API Promise、includes时:

// 新的 API
Promise.resolve(100).then(data => data);
[10, 20, 30].includes(20)

babel-polyfill兼容处理后:

window.Promise = function() {}
Array.prototype.includes = function () {}

重新定义了window.Promise和Array原型的方法,污染了全局环境.

babel-polyfill 的问题:

如使用方定义:window.Promise = function() {},与之前兼容处理 window.Promise = function() {} 出现冲突:

babel-runtime

babel-runtime配置使用:
① package.json 配置安装插件 @babel/plugin-transform-runtime@babel/runtime ,具体参见上面package.json配置;

② .babelrc文件配置plugins:引用plugin-transform-runtime,并配置选项:

{
    "presets": [
        [
            "@babel/preset-env", //es6+常用语法的解析
        ]
    ],
    "plugins": [
    [
            "@babel/plugin-transform-runtime",
            {
                "absoluteRuntime": false,
                "corejs": 3,
                "helpers": true,
                "regenerator": true,
                "useESModules": false
            }
        ]
    ]
}

babel-runtime兼容处理后:
Promise->_Promise,includes->_includes

所以babel-runtime不会污染全局环境

babel-polyfill VS babel-runtime

babel-polyfill:

babel-plugin-transform-runtime:

上一篇 下一篇

猜你喜欢

热点阅读