ECMAScript 6 模块简介

  • Zef Hemel
  • 廖煜嵘

2013 年 8 月 14 日

话题:JavaScript语言 & 开发

任何平台的其中一个重要特性, 除了需要支持代码库外就是模块。直到现在,Javascript 还不支持原生的模块化。结果是,各种解决方案都将模块添加到类库中,比如CommonJS modules(部分由node.js实现)和require.js。然而,作为下一代的 Javascript(官方称为 ECMAScript 6),模块终于被作为重要组成部分加入其中。Axel Rauschmayer 写了一篇介绍 ECMAScript 6 模块的文章,解析了它们是什么以及如何使用,并且如果目前想使用的话采用的方法(使用转换编译器)。

Axel 指出了 ES6 模块的设计目标如下:

ECMAScript 6 (ES6) 模块的目标是创建的格式能让 CJS(CommonJS 规范)和 AMD(Asynchronous Module Definition,异步模块定义)的用户都能满意。为此,它们的语法是 CJS 那样紧凑。在另一方面,它们的动态能力比不上 CJS(例如,你不能用正常的语法去有条件加载模块)。这有两个主要的优点:

  • 如果尝试导入未导出的将会得到编译时的错误
  • 可以很容易异步导入 ES6 的模块。

ES6 的模块标准由两部分组成:

  1. 声明式语法(导入和导出用)。
  2. 编程式 API 加载器:设置模块如何加载以及如何有条件地加载模块。

ES6 模块不再需要开发人员去将整个 JavaScript 文件的尴尬地包装成一个对象或函数闭报,这和以前大多数异步模块装载器在浏览器中的做法一样。相反,可以在最顶层进行定义,而只有函数和显式定义的导出变量将可以暴露给模块的消费者:

var privateVar = "this is a variable private to the module";
export var publicVar = "and this one is public";

export function returnPrivateVar() {
   return privateVar;
};

假设将上面的代码保存在 mymodule.js 中,我们现在可以用两种方法导入,或者是通过导入指定函数和变量,或者通过导入模块作为模块的对象:

import { returnPrivateVar, publicVar } from 'mymodule';
console.log(returnPrivateVar());

或者是:

import 'mymodule' as mm;
console.log(mm.returnPrivateVar());

新的模块标准也支持对模块的内嵌定义和动态模块加载。可以阅读Axel 的文章也了解更多相关信息。

如果想在目前尝试新的模块语法,可以有一些方法可供选择:

  • es6-module-transpiler 将 ES6 模块编译为 AMD 规范或者 CommonJS 规范的模块
  • ES6 module loader 则能支持动态加载 ES6 风格的模块
  • require-hm是一个 require.js 的插件能支持加载 ES6 模块
  • Traceur是 Google 的转换编译器,目的在于支持许多 Javascript 的特性包括 ES6 模块
  • TypeScript是微软的可选择的 Javascript 的一个版本,也支持 ES6 模块

查看英文原文:ECMAScript 6 Modules: What Are They and How to Use Them Today


感谢马国耀对本文的审校。

给 InfoQ 中文站投稿或者参与内容翻译工作,请邮件至editors@cn.infoq.com。也欢迎大家通过新浪微博(@InfoQ)或者腾讯微博(@InfoQ)关注我们,并与我们的编辑和其他读者朋友交流。

JavaScript语言 & 开发