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

1、前言:

当咱们还在沉迷于ES5的时候,却不知ES6早就已经发布几年了。时代在进步,WEB前端技术也在突飞猛进,是时候作些改变了!前端

ECMAScript 6(ES6)的发展速度很是之快,但现代浏览器对ES6新特性支持度不高,因此要想在浏览器中直接使用ES6的新特性就得借助别的工具来实现。
Babel是一个普遍使用的转码器,babel能够将ES6代码完美地转换为ES5代码,因此咱们不用等到浏览器的支持就能够在项目中使用ES6的特性。 node

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。
本文中,咱们不讨论ES6的语法特性,重点讲的是如何将ES6代码转码为ES5代码。 react

 

2、Babel转码:

若是你并无接触过ES6,当你看到下面的代码时,确定是有点懵逼的(这是什么鬼?心中一万头神兽奔腾而过),可是你没看错,这就是ES6。无论你看不看它,它都在这里。npm

	var a = (msg) => () => msg;

	var bobo = {
	  _name: "BoBo",
	  _friends: [],
	  printFriends() {
	    this._friends.forEach(f =>
	      console.log(this._name + " knows " + f));
	  }
	};

实际上,上面的这段代码经过Babel转换后,会变成:json

	"use strict";

	var a = function a(msg) {
	  return function () {
	    return msg;
	  };
	};

	var bobo = {
	  _name: "BoBo",
	  _friends: [],
	  printFriends: function printFriends() {
	    var _this = this;

	    this._friends.forEach(function (f) {
	      return console.log(_this._name + " knows " + f);
	    });
	  }
	};

好,言归正传,咱们尝试下用一些方法来实现上面的转码效果吧。gulp

一、直接安装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。以下所示:babel

	//......
	{
	  "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
二、工具配置法:

实际上,咱们能够经过前端自动化的不少工具来实现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

 

3、其余:

以上两种方法,在我本地亲测有效。固然,你能够选择更多其余的工具来处理,异曲同工,Anyway,让咱们一块儿来拥抱ES6吧!

固然,你也能够选择在线转码(测试体验用),地址是:http://babeljs.cn/repl/

相关文章
相关标签/搜索