ES6转换器之Babel
ES6部分功能没有支持,所以想学习ES6,得先有个转换器,就是将ES6的代码转换为ES5。
我这里用的是Gulp + Bable的形式来将ES6转换为ES5的。
前提:
(1)、Gulp和Bable都是基于node环境,如果不知道node,建议先看看”初探nodeJS”。
(2)、说到Gulp,如果你还不是很清楚的话,建议先了解Gulp(”细说Gulp”)。
OK,从无到有。接下来,我们就一步步搭建这个‘转换神器’吧。
| Get started |
因为是Gulp + Bable的形式,所以得先安装gulp和Bable模块。借助npm轻松搞定。
不过为了今后便于查看Gulp安装的相关信息,我们可以在项目根路劲中建立一个package.json文件,里面的内容如下:

--name--:项目名称(自己取,如上的"gulpPro");
--devDependencies--:用于记录项目依赖模块。
好了,下面开始安装吧。
1、 安装项目中的Gulp
npm install --save-dev gulp
2、 安装Gulp上的Bable插件
npm install --save-dev gulp-babel
3、 安装ES6转换ES5插件
npm install --save-dev babel-preset-es2015
好了,模块安装完后,我们再打开刚才我们创建的package.json文件,如下:

可以清晰地在devDpendencies中,看到我们刚才安装的模块依赖。
接下来,配置gulpfile.js的步骤就跟”细说Gulp”中的”小试牛刀之压缩Javascript”思路差不多。这里我们就依葫芦画瓢,得如下配置内容:
//引入gulp模块
var gulp = require('gulp');
//引入gulp-babel模块,用于转换ES6为ES5
var babel = require('gulp-babel');
//默认任务
gulp.task('default', function(){
//这里是将script文件下的js转换为ES5,并添加到dist文件夹中
gulp.src('script/*.js')
.pipe(babel())
.pipe(gulp.dest('dist'));
});
最后,我们再在根路径下新建一个.babelrc文件,内容如下:

因为我是以D盘的ES6文件夹作为的根路径,所以经过上面的步骤,ES6文件夹下现在是这样的:

好了,再在根路径下创建一个script文件夹,里面新建一个demo.js用于检验,配置是否成功。
demo.js里的内容为:
//直接在参数里赋值,属于ES6的规范,如y='world'
function log(x, y = 'world'){
console.log(x, y);
};
log('hello');
在cmd环境(D:\ES6下)输入gulp + 回车,运行。
如下:

这样就成功啦。你会发现在根路径下多了一个dist文件夹,里面还多了一个demo.js。
不错,这个js文件,就是转换为ES5的结果。
如下:

有了这个神器,我们就可以学习ES6咯。
但,为了让我们学习ES6时,效率更高,我们再来完善一下gulpfile.js里的配置内容。
因为,我们在学习ES6时,难免会发生语法之类的错误,当我们利用gulp去转换时,一旦遇见错误,就会报错且停止运行gulp。且,gulp自身报的错,无关紧要,在实际操作中,根本不知道这个错误是什么,非常影响效率。
So,我们可以利用stream-combiner2来解决这一问题。当gulp遇见错误时,利用stream-combiner2来捕获错误信息,并准确地告诉我们错误在哪。这样不就提高效率了么?
如下:

//引入gulp模块
var gulp = require('gulp');
//引入gulp-babel模块,用于转换ES6为ES5
var babel = require('gulp-babel');
//引入stream-combiner2捕获错误信息
var combiner = require('stream-combiner2');
//捕捉异常函数
var handleError = function(err){
console.log('\n');
console.log('Error!');
console.log('fileName: ' + err.fileName);
console.log('lineNumber: ' + err.loc.line);
console.log('message: ' + err.message);
console.log('plugin: ' + err.plugin);
console.log('\n');
};
//默认任务
gulp.task('default', function(){
//这里是将script文件下的js转换为ES5,并添加到dist文件夹中
var combined = combiner.obj([
gulp.src('script/*.js'),
babel(),
gulp.dest('dist')
]);
//利用combined捕获异常
combined.on('error', handleError);
});
entirCode
测试:倘若我们将script/demo.js改为如下这样,并取名为demo1.js:

因为我们引入了stream-combiner2模块,所以你得安装它
(npm install --save-dev stream-combiner2)
安装完成后,运行gulp,得如下结果:

Nice。出现问题不但没有终止gulp,且在最后,打印出了具体错误信息,这样我们检测错误就非常方便啦。
但是,这是在测试代码较少的情况下,如果代码数量很多呢?这字体不便于我们发现哦。所以为了更加完美,提高学习效率,我们可以利用gulp-util模块来指定字体颜色。这样,当出错信息我们标记为红色,不就显而易见了么?
修改代码如下:

//引入gulp模块
var gulp = require('gulp');
//引入gulp-babel模块,用于转换ES6为ES5
var babel = require('gulp-babel');
//引入stream-combiner2捕获错误信息
var combiner = require('stream-combiner2');
//引入gulp-util模块,用于实现自定义颜色的log
var gutil = require('gulp-util');
//捕捉异常
var handleError = function(err){
var colors = gutil.colors;
console.log('\n');
gutil.log(colors.red('Error!'));
gutil.log('fileName: ' + colors.red(err.fileName));
gutil.log('lineNumber: ' + colors.red(err.loc.line));
gutil.log('message: ' + err.message);
gutil.log('plugin: ' + colors.yellow(err.plugin));
};
//默认任务
gulp.task('default', function(){
//这里是将script文件下的js转换为ES5,并添加到dist文件夹中
/*
gulp.src('script/*.js')
.pipe(babel())
.pipe(gulp.dest('dist'));
*/
var combined = combiner.obj([
gulp.src('script/*.js'),
babel(),
gulp.dest('dist')
]);
combined.on('error', handleError);
});
entireCode
引入了gulp-util模块,所以你得安装它(npm install --save-dev gulp-util)
安装好后,再次运行gulp。
得如下结果:

好了,完美程度直逼100%。
为了更加完美,不用我们每次都手动去转换ES6,我们可以利用gulp-watch-path模块去监听文件,一旦文件变换,就转换。注:引入了gulp-watch-path模块,所以你得安装!!
如下:

//引入gulp模块
var gulp = require('gulp');
//引入gulp-babel模块,用于转换ES6为ES5
var babel = require('gulp-babel');
//引入stream-combiner2捕获错误信息
var combiner = require('stream-combiner2');
//引入gulp-util模块,用于实现自定义颜色的log
var gutil = require('gulp-util');
//引入gulp-watch-path模块,用于监听
var watchPath = require('gulp-watch-path');
//捕捉异常
var handleError = function(err){
var colors = gutil.colors;
console.log('\n');
gutil.log(colors.red('Error!'));
gutil.log('fileName: ' + colors.red(err.fileName));
gutil.log('lineNumber: ' + colors.red(err.loc.line));
gutil.log('message: ' + err.message);
gutil.log('plugin: ' + colors.yellow(err.plugin));
};
//默认任务
gulp.task('default', function(){
gulp.watch('script/*.js', function(event){
var paths = watchPath(event, 'script/', 'dist/');
var combined = combiner.obj([
gulp.src(paths.srcPath),
babel(),
gulp.dest(paths.distDir)
]);
combined.on('error', handleError);
});
});
entireCode
ES6转换器之Babel的更多相关文章
- Babel 转码器 § es6转换es5
Babel 转码器 § es6转换es5 实时转码 / Repl -babel-node / babel-register(自动转码引入babel-register模块) 配置文件.babelrc ...
- 用grunt进行ES6转换,再用uglify压缩所有js实例
1.首先安装node.js 去官网下载exe执行文件安装即可,安装完成后自带有npm管理. 2.安装grunt CLI 在项目根文件夹下执行如下代码: npm install -g grunt-cli ...
- 让浏览器兼容ES6语法(gulp+babel)
使用gulp+babel搭建ES6环境 前言 我们查阅资料可以知道ECMAScript 2015(简称ES6)已经于2015年发布,由于用户使用的浏览器版本在安装的时候可能早于ES6的发布,而到了今天 ...
- ES6学习之Babel的正确安装姿势
开始学习ES6,写点东西放上博客^_^ 本文介绍Babel6.x的安装过程~ 首先呢,可以使用Babel在线转换 https://babeljs.io/repl/ 然后进入主题:安装Babel(命令行 ...
- ES6入门一:ES6简介及Babel转码器
ES6简介 Babel转码器 Nodejs中使用ES6 WebPack中使用ES6及Babel转码插件 一.ES6简介与转码 1.1一个常见的问题,ECMAScript和JavaScript到底是什 ...
- webpack4 es6转换
在webpack里用es6语法, ie浏览器不识别,为了让浏览器识别,需要用到bebal转换; bebal,英文是通天塔 的意思, 我们常说的巴比伦也是这个词;我估计是当初设计者是想用它作为一个沟通e ...
- ES6转换ES5
各大浏览器的最新版本,对 ES6 的支持可以查看kangax.github.io/es5-compat-table/es6/.随着时间的推移,支持度已经越来越高了,超过 90%的 ES6 语法特性都实 ...
- 让nodeJS支持ES6的词法----babel的安装和使用
要使用Babel, 我们需要nodeJS的环境和npm, 主要安装了nodeJS, npm就默认安装了 , 现在安装nodeJS很简单了, 直接下载安装就好了: 安装es-checker 在使用Bab ...
- ES6 系列之 Babel 是如何编译 Class 的(下)
前言 ES5 寄生组合式继承 function Parent (name) { this.name = name; } Parent.prototype.getName = function () { ...
随机推荐
- 【原】Android热更新开源项目Tinker源码解析系列之二:资源文件热更新
上一篇文章介绍了Dex文件的热更新流程,本文将会分析Tinker中对资源文件的热更新流程. 同Dex,资源文件的热更新同样包括三个部分:资源补丁生成,资源补丁合成及资源补丁加载. 本系列将从以下三个方 ...
- 【趣事】用 JavaScript 对抗 DDOS 攻击
继续趣事分享. 上回聊到了大学里用一根网线发起攻击,今天接着往后讲. 不过这次讲的正好相反 -- 不是攻击,而是防御.一个奇葩防火墙的开发经历. 第二学期大家都带了电脑,于是可以用更高端的方法断网了. ...
- 【AutoMapper官方文档】DTO与Domin Model相互转换(上)
写在前面 AutoMapper目录: [AutoMapper官方文档]DTO与Domin Model相互转换(上) [AutoMapper官方文档]DTO与Domin Model相互转换(中) [Au ...
- myeclipse学习总结一(在MyEclipse中设置生成jsp页面时默认编码为utf-8编码)
1.每次我们在MyEclispe中创建Jsp页面,生成的Jsp页面的默认编码是"ISO-8859-1".在这种情况下,当我们在页面中编写的内容存在中文的时候,就无法进行保存.如下图 ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(64)-WebApi与Unity注入
系列目录 前言: 有时候我们系统需要开放数据给手机App端或其他移动设备,不得不说Asp.net WebApi是目前首选 本节记录Asp.net MVC WebApi怎么利用Unity注入.系列开头已 ...
- C#——传值参数(1)
//我的C#是跟着猛哥(刘铁猛)(算是我的正式老师)<C#语言入门详解>学习的,微信上猛哥也给我讲解了一些不懂得地方,对于我来说简直是一笔巨额财富,难得良师! 这次与大家一起学习C#中的值 ...
- 集合(set)-Python3
set 的 remove() 和 discard() 方法介绍. 函数/方法名 等价操作符 说明 所有集合类型 len(s) 集合基数:集合s中元素个数 set([obj]) 可变集合工 ...
- Android之使用Bundle进行IPC
一.Bundle进行IPC介绍 四大组件中的三大组件(Activity.Service.Receiver)都是支持在Intent中传递Bundle数据的,由于Bundle实现了Parcelable接口 ...
- 技术笔记:Indy的TIdSMTP改造,解决发送Html和主题截断问题
使用Indy来发邮件坑不少啊,只不过有比没有好吧,使用delphi6这种老工具没办法,只能使用了新一点的Indy版本9,公司限制... 1.邮件包含TIdText和TIdAttachment时会出现T ...
- 曲演杂坛--蛋疼的ROW_NUMBER函数
使用ROW_NUMBER来分页几乎是家喻户晓的东东了,而且这东西简单易用,简直就是程序员居家必备之杀器,然而ROW_NUMBER也不是一招吃遍天下鲜的无敌BUG般存在,最近就遇到几个小问题,拿出来供大 ...