如何使用Babel将ES6转码为ES5

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何使用Babel将ES6转码为ES5相关的知识,希望对你有一定的参考价值。

1、直接安装Babel法:

1.1) 首先全局安装Babel。

$ npm install -g babel-cli //也可以通过直接将Babel安装到项目中,在项目根目录下执行下面命令,同时它会自动在package.json文件中的devDependencies中加入babel-cli //在执行安装到项目中命令之前,要先在项目根目录下新建一个package.json文件。 $ npm install -g babel-cli --save-dev
如果将babel直接安装到项目中,它会自动在package.json文件中的devDependencies中加入babel-cli。如下所示:

//...... "devDependencies": "babel-cli": "^6.22.2"
1.2) Babel的配置文件是.babelrc,存放在项目的根目录下。使用Babel的第一步,就是配置这个文件。

这个文件的完整文件名是 “.babelrc”,注意最前面是有个“.”的。由于我的电脑是Windows系统,所以在新建这个文件的时候老是提示 “必须键入文件名” 的错误。后来谷歌了下,发现创建这个文件的时候,把文件名改成“.babelrc.”,注意是前后都有一个点,这样就可以保存成功了

"presets": [], "plugins": []
1.3) presets字段设定转码规则,官方提供以下的规则集,你可以根据需要安装。

点击此处到Babel中文官网presets配置页面:Babel Plugins

# ES2015转码规则 $ npm install --save-dev babel-preset-es2015 # react转码规则 $ npm install --save-dev babel-preset-react # ES7不同阶段语法提案的转码规则(共有4个阶段)追答

选装一个 $ npm install --save-dev babel-preset-stage-0 $ npm install --save-dev babel-preset-stage-1 $ npm install --save-dev babel-preset-stage-2 $ npm install --save-dev babel-preset-stage-3
1.4) 根据官网的提示,当我们用npm安装好这些插件工具之后,我们需要将这些规则加入到.babelrc中去。如下所示:

"presets": [ "es2015", "react", "stage-2" ], "plugins": []
1.5) 转码、转码的规则:

# 转码结果输出到标准输出 $ babel test.js # 转码结果写入一个文件 # --out-file 或 -o 参数指定输出文件 $ babel a.js --out-file b.js # 或者 $ babel a.js -o b.js # 整个目录转码 # --out-dir 或 -d 参数指定输出目录 $ babel src --out-dir lib # 或者 $ babel src -d lib # -s 参数生成source map文件 $ babel src -d lib -s
2、工具配置法:

实际上,我们可以通过前端自动化的很多工具来实现ES6的转码配置,比如,常见的grunt、gulp、Webpack和Node等。下面我就简单的说下我较为熟悉的gulp配置法。

点击此处到Babel中文官网Tool配置页面:Babel Tool

2.1) 首先,我们需要在项目中安装gulp:

$ npm install gulp --save-dev
2.2) 然后,我们需要在项目中安装gulp-babel:

$ npm install --save-dev gulp-babel
当执行完上面的两个命令后,我们会发现根目录下的package.json文件内容已经被自动修改成:

"devDependencies": "babel-cli": "^6.22.2", "gulp": "^3.9.1", "gulp-babel": "^6.1.2"
2.3) 编写gulpfile.js文件,文件内容如下所示:

var gulp = require("gulp"); var babel = require("gulp-babel"); gulp.task("default", function () return gulp.src("src/a.js") .pipe(babel()) .pipe(gulp.dest("lib")); );
当我们在当前项目目录下运行如下命令后,会发现原本在src文件夹中的a.js(按照ES6标准编写的)文件已经被转码成ES5标准的a.js,并放在了lib文件夹里面。

$ gulp default #或者用下面的命令也行 $ gulp

参考技术A 当我们还在沉迷于ES5的时候,殊不知ES6早就已经发布几年了。时代在进步,WEB前端技术也在日新月异,是时候做些改变了!

ECMAScript 6(ES6)的发展速度非常之快,但现代浏览器对ES6新特性支持度不高,所以要想在浏览器中直接使用ES6的新特性就得借助别的工具来实现。
Babel是一个广泛使用的转码器,babel可以将ES6代码完美地转换为ES5代码,所以我们不用等到浏览器的支持就可以在项目中使用ES6的特性。
babel 6与之前版本的区别:
之前版本只要安装一个babel就可以用了,所以之前的版本包含了一大堆的东西,这也导致了下载一堆不必要的东西。但在babel

6中,将babel拆分成两个包:babel-cli和babel-core。如果你想要在CLI(终端或REPL)使用babel就下载babel-cli,如果想要在node中使用就下载babel-core。
babel 6已结尽可能的模块化了,如果还用babel
6之前的方法转换ES6,它会原样输出,并不会转化,因为需要安装插件。如果你想使用箭头函数,那就得安装箭头函数插件npm install
babel-plugin-transform-es2015-arrow-functions。本回答被提问者采纳

1.Babel转码器

为什么要使用Babel?

在当代环境中虽然对ES6的支持越来越好,但是大多数还是不支持ES6,这时候我们就需要把已经写好的ES6代码转换成ES5,而Babel就是将ES6转化成ES5的转码器,被广泛使用。
举个栗子:

// 转码前
input.map(item => item + 1);

// 转码后
input.map(function (item) {
  return item + 1;
});

配置文件 .babelrc

.babelrc是babel的配置文件,放在项目的根目录下,比如现有的项目:

{
  // presets 是用来设置转码规整的,es2015就是ES6,
  // stage-2其实是一个系列,它是ES7的编码规则,有stage-0[,1,2,3], 四选一
  "presets": ["es2015", "stage-2"],
  "plugins": ["lodash", "transform-runtime"],
  "comments": false
}

基本用法如下。

# 转码结果输出到标准输出
$ babel example.js

# 转码结果写入一个文件
# --out-file 或 -o 参数指定输出文件
$ babel example.js --out-file compiled.js
# 或者
$ babel example.js -o compiled.js

# 整个目录转码
# --out-dir 或 -d 参数指定输出目录
$ babel src --out-dir lib
# 或者
$ babel src -d lib

# -s 参数生成source map文件
$ babel src -d lib -s

你也可以将babel-cli安装到项目中去:

$ npm install --save-dev babel-cli

然后,改写package.json。

{
  // ...
  "devDependencies": {
    "babel-cli": "^6.0.0"
  },
  // 这里build只是随便启的名字,运行是质询要npm run build就行了
  "scripts": {
    "build": "babel src -d lib"
  },
}

babel-polyfill

Babel默认只转换新的JavaScript句法(syntax),而不转换新的API,比如Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise等全局对象,以及一些定义在全局对象上的方法(比如Object.assign)都不会转码。
举例来说,ES6在Array对象上新增了Array.from方法。Babel就不会转码这个方法。如果想让这个方法运行,必须使用babel-polyfill,为当前环境提供一个垫片。
安装命令如下。

$ npm install --save babel-polyfill
然后,在脚本头部,加入如下一行代码。
import 'babel-polyfill';
// 或者
require('babel-polyfill');

浏览器环境

当你不想做这些操作,或者现有的项目没有webpack等构架工具时,这一步转码过程可以放在浏览器中,只不过从Babel 6.0开始,不再直接提供浏览器版本,而是要用构建工具构建出来。如果你没有或不想使用构建工具,可以通过安装5.x版:

$ npm install [email protected]

运行上面的命令以后,就可以在当前目录的node_modules/babel-core/子目录里面,找到babel的浏览器版本browser.js(未精简)和browser.min.js(已精简)。
然后,将下面的代码插入网页。

<script src="node_modules/babel-core/browser.js"></script>
<script type="text/babel">
// Your ES6 code
</script>

上面代码中,browser.js是Babel提供的转换器脚本,可以在浏览器运行。用户的ES6脚本放在script标签之中,但是要注明type="text/babel"。

另一种方法是使用babel-standalone模块提供的浏览器版本,将其插入网页。

<script src="https://cdnjs.cloudflare.com/ajax/libs/babel-standalone/6.4.4/babel.min.js"></script>
<script type="text/babel">
// Your ES6 code
</script>

但是要注意的是,如果这样做浏览器会是是转换ES6代码,会使性能下降。

以上是关于如何使用Babel将ES6转码为ES5的主要内容,如果未能解决你的问题,请参考以下文章

如何使用Babel将ES6转码为ES5?

JavaScript 学习笔记-- ES6学习介绍以及Babel的使用

WebStorm ES6 语法支持设置

Babel 转码器 § es6转换es5

常见的ES6转码(编译)工具——Babel转码器Traceur转码器

1.Babel转码器