Babel transcoding configuration is every front-end children’s shoes in the daily work will encounter. I started by researching configurations online and struggled to upgrade to Babel 7, so I decided to write down what I learned and understood in hopes of helping kids in need.

I am not going to cover every configuration item in detail here, after all, official documentation is the most authoritative. This article will discuss the main libraries involved in Babel 7 transcoding and their relationships, as well as how to choose configuration schemes and some tips for different project types.

The main libraries involved

Babel 7 transcoding involves four major players:

  • @babel/preset-env
  • @babel/polyfill
  • @babel/runtime
  • @babel/plugin-transform-runtime

What are the functions and connections of these four libraries? I believe that a lot of children’s shoes with me at the beginning is always a little confused, the following is a simple explanation, of course, the most detailed content or to see the official documents.

@babel/preset-env

This is the Babel transcoding environment preset, which adjusts syntax conversion rules and environment shim patches based on the target environment you set (such as the browser version range to support), and has the advantage of being smarter and smaller than its predecessor.

@babel/polyfill

This can simulate a nearly complete ES6+ environment (no lower than the Stage 4 proposal). For example, new Class: Promise, Map, static methods: array. from, new prototype methods: array.prototype. includes, etc. Note, however, that using polyfill contaminates the whole world because it provides support for the prototype approach.

Note that this library has been deprecated since Babel 7.4.0 and replaced with the following:

import 'core-js/stable';
import 'regenerator-runtime/runtime';
Copy the code

But the idea is the same.

@babel/runtime

This library provides some help functions in transcoding. To put it simply, in the process of transcoding, for some new syntax, a small function will be abstracted and the substitution will be completed in the process of transcoding. Let’s say we write a class Circle {… }, the transcoding will look like this:

function _classCallCheck(instance, Constructor) {
  / /...
}

var Circle = function Circle() {
  _classCallCheck(this, Circle);
};
Copy the code

So every time you convert the new class syntax, you use _classCallCheck instead.

@babel/plugin-transform-runtime

This works with @babel/ Runtime above. Following the example above, if your project has multiple js files with classes that need transcoding, each file will have a duplicate _classCallCheck function definition, One of the main functions of the plugin-transform-Runtime is to reference these helper functions from a common place, eliminating code redundancy and thus reducing packaging volume:

var _classCallCheck = require("@babel/runtime/helpers/classCallCheck");

var Circle = function Circle() {
  _classCallCheck(this, Circle);
};
Copy the code

In addition, he provides a sandbox environment. If we use @babel/ Polyfill to support the use of some of the new ES6+ features (Promise, Map, etc.), it will cause global contamination. Sandbox environment support can be enabled by configuring the plugin-transform-Runtime corejs option to introduce the desired new functionality separately to the files that currently require transcoding.

Installation instructions

Let’s take a look at the installation above:

npm install --save @babel/runtime, @babel/polyfill
npm install --save-dev @babel/preset-env, @babel/plugin-transform-runtime
Copy the code

Some of you may have the same question as I did at that time: @babel/ Runtime is not used in the process of packaging and transcoding, how can it be installed as runtime environment dependent? Remember that plugin-transform-Runtime references these helper functions from a uniform location, which means that the code is executed at runtime, so of course it is runtime dependent.

And here’s a little trick for you. Sometimes we install the configuration @babel/preset-stage-x to use a new preset, when these preset-stage-x are already deprecated in Babel 7, we have to install the required plug-ins one by one, and change the configuration of.babelrc, which is annoying. How do I simplify this? We can use the following methods to simplify installation, such as stage-2:

  1. First of all:npm install --save-dev @babel/preset-stage-2
  2. And then:npx babel-upgrade --write --install

And we’re done. The babel-upgrade tool will automatically install all the plug-ins you need and change the relevant parts of package.json and.babelrc files.

Configuration suggestions for different project types

Here we are mainly divided into NPM library projects and business projects to suggest configuration, only for your reference. Of course preset-env is installed first, and preset for your target environment.

NPM library project

The runtime and the plugin-transform-Runtime must both be installed. Note in particular that Polyfill is not installed, my recommendation is that the business project be responsible for the gasket patch, as Polyfill contaminates the whole world.

Business project

This is our specific business items such as website and so on. Runtime, plugin-transform-Runtime, and Polyfill should be installed, and @babel/preset-env should be configured with useBuiltIns: ‘Entry’, this is to intelligently choose which polyfills to import on the project entry file based on the target environment instead of all, this is what preset-env will help you do (refer to the polyfill documentation for details), Finally, don’t forget to import ‘@babel/polyfill’ on the entry file.

This is my summary of the Babel 7 transcoding postures. If you have any questions or suggestions for this article, please feel free to post them here.

Welcome star and follow my JS blog: Whisper By JavaScript

The resources

  • Babel Docs