[译]使用Babel和Browserify创建你的ES6项目
原文地址:Setting up an ES6 Project Using Babel and Browserify
JavaScript的发展日新月异,ES6很快就要接管JS了。很多著名的框架像AngularJS 2、React Native已经开始支持ES6了。我们是时候准备拥抱变化了,所以我们应该开始在几乎所有的浏览器支持之前使用ES6码代码了。
本文将要介绍如何使用Babel和Browerify来创建项目并且编写能够运行在老版本浏览器上的现代代码。Babel将ES6代码编译为大多数浏览器(包括IE9)支持的ES5代码。Browserify可以让我们遵循CommonJS规范书写代码,然后经过包装在浏览器中使用。
创建package.json文件
首先,我们看一下我们将要创建的Demo的文件结构。

项目的根目录下,有两个文件:Gruntfile.js和package.json,两个文件夹dist和modules。modules文件夹下包括用ES6编写的所有模块,dist文件夹下包含编译和打包后的ES5文件。我没有在文件夹里包含.gitignore文件是因为它只是一个工具文件没什么乱用。
现在我们来创建package.json文件,一个标准的package.json包含许多字段,比如description、version、author还有其他神马的,但在这个项目我们只写一些比较重要的。
package.json内容如下:
{
"name": "browserify-babel-demo",
"main": "dist/module.js",
"devDependencies": {
"grunt": "^0.4.5",
"babelify": "^6.1.0",
"grunt-browserify": "^3.8.0",
"grunt-contrib-watch": "^0.6.1"
}
}
从上述文件可以看到,项目中使用到的有:
- Grunt JavaScript任务构建工具
- grunt-browserify Grunt browserify任务
- babelify Browserify的babel转换器
- grunt-contrib-watch 监听JavaScript的每次改变然后选择性的执行任务,在我们的例子中,文件每次改变都要执行Browserify任务。
devDependencies中的模块只在开发环境中使用,而不是在代码运行过程中。模块的版本号可以根据使用设置。
现在在项目根目录下运行 npm install来安装package.json中声明的依赖模块,如果你还不熟悉npm,建议你读一下这篇文章。
(译者注:要想使用最新版本的依赖模块,可以不事先在package.json文件写好,执行如下命令安装:npm install grunt --save-dev,安装完成后依赖模块会自动出现在package.json中)。
创建Gruntfile.js
本文假设你已经了解Grunt,并且知道Gruntfile.js是如何和Grunt工作的。如果不熟悉,我建议在阅读下面的内容前,看一下这篇文章。
使用ES6书写的JavaScript文件可以使用js或者es6作为扩展名,这里为了简洁,统一使用js作为扩展名,Gruntfile.js代码如下:
module.exports = function (grunt) {
grunt.initConfig({
browserify: {
dist: {
options: {
transform: [
["babelify", {
loose: "all"
}]
]
},
files: {
// if the source file has an extension of es6 then
// we change the name of the source file accordingly.
// The result file's extension is always .js
"./dist/module.js": ["./modules/index.js"]
}
}
},
watch: {
scripts: {
files: ["./modules/*.js"],
tasks: ["browserify"]
}
}
});
grunt.loadNpmTasks("grunt-browserify");
grunt.loadNpmTasks("grunt-contrib-watch");
grunt.registerTask("default", ["watch"]);
grunt.registerTask("build", ["browserify"]);
};
我们定义了两个Grunt任务:
- grunt default/grunt:当我们在项目根目录运行这个命令,这个任务会监听modules文件夹下所有JS文件的变化。当检测到任何变化时,Grunt都会执行Browserify任务。任务终断之前,watch任务会一直运行。Ctrl+C来终断任务。
- grunt build:Browserify任务运行一次后停止。
Browserify任务每一次执行都会将modules文件下的所有ES6代码打包成一个JavaScript文件,然后通过Babelify将ES6代码转换成ES5代码。
从上面的代码看到,我们给babelify的设置是loose:"all",是因为我们希望转换出的ES5代码和我们写的ES6代码能够足够的接近,而不是严格的按照规范,这样,对ES6初学者来说更容易调试。Babel提供的所有选项见这里。
写点ES6代码
这个demo只使用一点ES6的特性,比如import和export。如果你想深入学习ES6,可以看看SitePoint上的这些文章。你将会学习到ES6提供的那些新奇而且令人激动的特性。
在我们的demo里我们将在modules文件夹下创建两个文件,index.js和import.js,前面一个文件是项目的主文件,后一个文件作为一个模块提供了所有的函数和变量。也就是说,index.js会从import.js中导入(import)所有的函数和变量。
import.js文件如下:
var sum = (a, b = 6) => (a + b);
var square = (b) => {
return b * b;
};
var variable = 8;
class MyClass {
constructor(credentials) {
this.name = credentials.name;
this.enrollmentNo = credentials.enrollmentNo
}
getName() {
return this.name;
}
}
export { sum, square, variable, MyClass };
import.js作为一个模块,对外提供了一个变量、一个类和函数表达式(箭头函数书写)。模块中定义的函数和变量对外是不可见的,除非显式的导出(export)他们。你可以使用export关键字。在import.js的最后一行,我们到处了sum、square、variable、MyClass。
在index.js文件中,我们使用import关键字导入import.js中的所有函数和变量,index.js成为了项目的主文件。从下面的index.js文件内容可以看到,我们是怎么使用导入的square函数和MyClass的。我们可以从任意多的文件中导入任何变量和方法。
import {sum, square, variable, MyClass} from './import';
console.log(square(5));
var cred = {
name: 'Ritesh Kumar',
enrollmentNo: 11115078
}
var x = new MyClass(cred);
//Ritesh Kumar
console.log(x.getName());
如果我们想导入一个es6扩展名的模块,那么我们必须在import中写完整的文件名。看下面的例子:
// if file extension of the importing file is .js
// both below mentioned methods work
import { sum, square, variable, MyClass } from './import';
import { sum, square, variable, MyClass } from './import.js'
//if file extension of the importing file is .es6
// its mandatory to add the extension
import { sum, square, variable, MyClass } from './import.es6';
假如我们正在使用Browserify,我们依然可以使用require()方法导入符合CommonJS规范的模块。例如:我们想使用导入jQuery作为一个模块,可以这样:
var $ = require('path/to/jquery');
$(window).click(function(){
//do something
});
Babel可以转换ES6到ES5,但不能打包模块。Browserify登场!
ES6的import、export结合require方法使得我们可以自由的用模块来组织我们的客户端代码,同时又可以使用新版本的JavaScript书写我们的代码。
只要我们在终端运行grunt命令就会:
- Browserify把所有的文件打包成一个JavaScript文件
- 打包后的文件通过Babelify转换成为ES5代码
- 生成一个名为module.js的文件,可以运行在所有的现在浏览器上,包括IE9
那么module.js长啥样呢,看:
(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
"use strict";
exports.__esModule = true;
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var sum = function sum(a) {
var b = arguments[1] === undefined ? 6 : arguments[1];
return a + b;
};
var square = function square(b) {
"use strict";
return b * b;
};
var variable = 8;
var MyClass = (function () {
function MyClass(credentials) {
_classCallCheck(this, MyClass);
this.name = credentials.name;
this.enrollmentNo = credentials.enrollmentNo;
}
MyClass.prototype.getName = function getName() {
return this.name;
};
return MyClass;
})();
exports.sum = sum;
exports.square = square;
exports.variable = variable;
exports.MyClass = MyClass;
},{}],2:[function(require,module,exports){
'use strict';
var _import = require('./import');
console.log((0, _import.square)(5));
var cred = {
name: 'Ritesh Kumar',
enrollmentNo: 11115078
};
var x = new _import.MyClass(cred);
console.log(x.getName());
},{"./import":1}]},{},[2]);
这个文件可以和其他普通的文件一样用在你的Web页面里,如果你愿意,你也可以使用其他的Grunt任务,比如grunt-uglify、grunt-rev或者其他的任务,对module.js进行操作,操作完成后,你就可以在html页面中使用了。
<!-- Usage of the final bundled file in html --> <script src="path/to/module.js"></script>
结论
本文介绍了如何使用JavaScript的新特性来创建项目,此外,我还介绍了如何使用grunt-browserify和babelify来配置Grunt任务,我们创建了一个示例项目来展示他们如何工作,ES6代码如何转换为ES5代码。
我希望你喜欢这篇文章,并且期待着你的评论。你也可以来这里把玩一下这个示例项目。
[译]使用Babel和Browserify创建你的ES6项目的更多相关文章
- 使用Gulp和Browserify创建多个绑定文件
Browserify是一个Javascript的绑定工具,帮助我们理顺module之间的依赖关系.Gulp用来优化workflow.两者的共同点都是使用流,但在使用流方面也有不同之处: Browser ...
- 【转】用systemJS+karma+Jasmine+babel环境去编写简单的ES6工程
原文链接:http://www.cnblogs.com/shuoer/p/7779131.html 用systemJS+karma+Jasmine+babel环境去编写简单的ES6工程 首先解释下什么 ...
- 创建第一个Maven项目
-----------------------siwuxie095 创建第一个 Maven 项目 1.打开 Ec ...
- 用Kotlin创建第一个Android项目(KAD 01)
原文标题:Create your first Android project using Kotlin (KAD 01) 作者:Antonio Leiva 时间:Nov 21, 2016 原文链接:h ...
- IntelliJ IDEA上创建maven Spring MVC项目
IntelliJ IDEA上创建Maven Spring MVC项目 各软件版本 利用maven骨架建立一个webapp 建立相应的目录 配置Maven和SpringMVC 配置Maven的pom.x ...
- 3.创建第一个android项目
安卓开发学习笔记 1.安卓开发之环境搭建 2.SDK目录结构和adb工具及命令介绍 3.创建第一个android项目 1.打开Eclipse,选择File——>new——>others.. ...
- soapui中文操作手册(一)----创建一个新的项目
1) 创建一个新的项目 点击项目,选择新建项目SOAP.这将打开一个新的SOAP项目对话框. 注意:你也可以做CTRL + N(WIN)或CMD+ N(MAC)来创建一个新的SOAP项目. 在新的SO ...
- step2-------使用myeclipse创建maven java web项目
1.文章内容概述: 在对项目需求进行分析之后,决定使用maven对我的java web项目进行管理,这篇文章记录了使用myeclipse创建maven java web项目的过程. 2.开发环境: j ...
- 在 Visual Studio 2013 中创建 ASP.NET Web 项目(0):专题导航 [持续更新中]
写在前面的话 随着 Visual Studio 2013 的正式推出,ASP.NET 和 Visual Studio Web 开发工具 也发布了各自的最新版本. 新版本在构建 One ASP.NET ...
随机推荐
- HDU 1077Catching Fish(简单计算几何)
Catching Fish Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) T ...
- PHP写入文件用file_put_contents代替fwrite优点多多(转)
使用php有一段时间了,之前一直用fwrite写入文件,不过当我知道file_put_contents这个函数之后,fwrite就比较少用了,file_put_contents比fwrite代码更简洁 ...
- [原创]如何写好SqlHelper 之终章
精简的美丽...... 标题有点大.但是,我觉得99%的接近了. 好了,下面我们来说说一个SqlHelper为了适应各种不同的业务需要,它应该具备哪些基本要素. 第一点.可控的事务. 事务是数据库操作 ...
- AngularJS - 定时器 倒计时例子
<body> <div ng-app="myApp"> <div ng-controller="firstController"& ...
- cocos2d-x3.x使用rapidjson
rapidjson效率高,所以之前cocostudio里面解析用的jsoncpp也换成了rapidjson. 引擎又带有rapidjson库,所以不用单独去下载,直接就可以用. 这里主要写一下关于解析 ...
- delphi xe5 android tts(Text To Speech)
TTS是Text To Speech的缩写,即“从文本到语音”,是人机对话的一部分,让机器能够说话. 以下代码实现xe5 开发的文本转语音的方法 和访问蓝牙一样,这里用javaclass的接口实现 接 ...
- Python_sklearn机器学习库学习笔记(五)k-means(聚类)
# K的选择:肘部法则 如果问题中没有指定 的值,可以通过肘部法则这一技术来估计聚类数量.肘部法则会把不同 值的成本函数值画出来.随着 值的增大,平均畸变程度会减小:每个类包含的样本数会减少,于是样本 ...
- SQL Server批量更新数据
项目中有一个位置需要批量插入几万条数据,批量insert等待时间简直...用SqlBulkCopy后,之前需要1分钟左右的sql现在只要一眨眼(真的只要一眨眼) 稍后这个功能要加到另外一个项目中,另外 ...
- HttpClient(4.3.5) - HTTP Authentication
HttpClient provides full support for authentication schemes defined by the HTTP standard specificati ...
- spring+hibernate管理多个数据源(非分布式事务)
本文通过一个demo,介绍如何使用spring+hibernate管理多个数据源,注意,本文的事务管理并非之前博文介绍的分布式事务. 这个demo将使用两个事务管理器分别管理两个数据源.对于每一个独立 ...