任何平台的其中一个重要特性, 除了需要支持代码库外就是模块。直到现在,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 的模块标准由两部分组成:
- 声明式语法(导入和导出用)。
- 编程式 API 加载器:设置模块如何加载以及如何有条件地加载模块。
ES6 模块不再需要开发人员去将整个 JavaScript 文件的尴尬地包装成一个对象或函数闭报,这和以前大多数异步模块装载器在浏览器中的做法一样。相反,可以在最顶层进行定义,而只有函数和显式定义的导出变量将可以暴露给模块的消费者:
<strong>var</strong> privateVar = "this is a variable private to the module"; <strong>export var</strong> publicVar = "and this one is public"; <strong>export function</strong> returnPrivateVar() { <strong>return</strong> privateVar; };
假设将上面的代码保存在 mymodule.js 中,我们现在可以用两种方法导入,或者是通过导入指定函数和变量,或者通过导入模块作为模块的对象:
<strong>import</strong> { returnPrivateVar, publicVar } <strong>from</strong> 'mymodule'; console.log(returnPrivateVar());
或者是:
<strong>import</strong> 'mymodule' <strong>as</strong> 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 )关注我们,并与我们的编辑和其他读者朋友交流。
评论