Babel插件:@babel/plugin-transform-runtime

一 概述

每个Babel编译后的脚本文件,都以导入的方式使用Babel的帮助函数,而不是每个文件都复制一份帮助函数的代码。

1 优点

(1)提高代码重用性,缩小编译后的代码体积。

(2)防止污染全局作用域。(启用corejs配置)

babel-polyfill会将Promise等添加成全局变量,污染全局空间。

① 默认使用@babel/runtime,corejs配置为2时,改为使用@babel/runtime-corejs2。

② 几个包的包含关系。

   babel-polyfill仅仅是引用core-js、regenerator-runtime这两个npm包。

   @babel/runtime包含两个文件夹:helpers(定义了一些处理新的语法关键字的帮助函数)、regenerator(仅仅是引用regenerator-runtime这个npm包)。

   @babel/runtime-corejs2包含三个文件夹:core-js(引用core-js这个npm包)、helpers(定义了一些处理新的语法关键字的帮助函数)、regenerator(仅仅是引用regenerator-runtime这个npm包)。

   可以看出,@babel/runtime-corejs2≈@babel/runtime + babel-polyfill:

   @babel/runtime只能处理语法关键字,而@babel/runtime-corejs2还能处理新的全局变量(例如,Promise)、新的原生方法(例如,String.padStart );

   使用了@babel/runtime-corejs2,就无需再使用@babel/runtime了。

   

 

二 项目结构

三 搭建环境

# 安装gulp
yarn add --dev gulp
# 安装Babel 7
yarn add --dev gulp-babel@next
yarn add --dev gulp-babel@next @babel/core
# 安装preset
yarn add --dev @babel/preset-env
# 安装pugin
yarn add --dev @babel/plugin-transform-runtime

四 创建配置文件

(1)gulpfile.js

 

var gulp = require("gulp");
var babel = require("gulp-babel");

gulp.task("default", function () {
  return gulp.src("src/**/*.js")
    .pipe(babel())
    .pipe(gulp.dest("dist"));
});

(2).babelrc

{
  "presets": ["@babel/preset-env"],
  "plugins": [
    [
      "@babel/plugin-transform-runtime",
      {
        "corejs": 2,
        "helpers": true,
        "regenerator": true,
        "useESModules": false
      }
    ]
  ]
}

五 创建脚本文件

(1)apple.js

  

class Apple{
    constructor(){
        this.name = Symbol('apple');
        this.attrs = new Map();
    }
    
    hello(){
        console.log('hello');
    }
}

(2)orange.js

class Apple{
    constructor(){
        this.name = Symbol('orange');
        this.attrs = new Map();
    }
    
    hello(){
        console.log('hello');
    }
}

六 编译后文件

(1)apple.js

"use strict";

var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");

var _map = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/map"));

var _symbol = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/symbol"));

var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));

var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));

var Apple =
/*#__PURE__*/
function () {
  function Apple() {
    (0, _classCallCheck2.default)(this, Apple);
    this.name = (0, _symbol.default)('apple');
    this.attrs = new _map.default();
  }

  (0, _createClass2.default)(Apple, [{
    key: "hello",
    value: function hello() {
      console.log('hello');
    }
  }]);
  return Apple;
}();

(2)orange.js

"use strict";

var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");

var _map = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/map")); 

var _symbol = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/symbol"));

var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));

var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));

var Apple =
/*#__PURE__*/
function () {
  function Apple() {
    (0, _classCallCheck2.default)(this, Apple);
    this.name = (0, _symbol.default)('orange');
    this.attrs = new _map.default();
  }

  (0, _createClass2.default)(Apple, [{
    key: "hello",
    value: function hello() {
      console.log('hello');
    }
  }]);
  return Apple;
}();
原文地址:https://www.cnblogs.com/sea-breeze/p/10490672.html