modules是ES6引入的最重要一个特性。 
所以以后再写模块,直接按照ES6的modules语法来写,然后用 babel + browserify 来打包就行了。

modules规范分两部分,一部分是如何导出,一部分是如何导入。

基本用法

命名导出(named exports)

可以直接在任何变量或者函数前面加上一个 export 关键字,就可以将它导出。 
这种写法非常简洁,和平时几乎没有区别,唯一的区别就是在需要导出的地方加上一个 export 关键字。 
比如:

  1. export const sqrt = Math.sqrt;
  2. export function square(x) {
  3. return x * x;
  4. }
  5. export function diag(x, y) {
  6. return sqrt(square(x) + square(y));
  7. }

然后在另一个文件中这样引用:

  1. import { square, diag } from 'lib';
  2. console.log(square(11)); // 121
  3. console.log(diag(4, 3));

你可能会注意到这个奇怪的语法 { square, diag } 不就是前面讲过的 destructing吗。所以你会以为还可以这样写:

  1. import lib from 'lib';
  2. square = lib.square;

但是其实这样是错的,因为 import { square, diag } from 'lib’; 是import的特有语法,并不是 destructing 语法,所以其实import的时候并不是直接把整个模块以对象的形式引入的。

如果你希望能通过 lib.square 的形式来写,你应该这样导入:

  1. import * as lib from 'lib';
  2. square = lib.square;

不过值得注意的一点是,如果你直接用babel编译,执行是会报错的。因为 babel 并不会完全编译 modules,他只是把 ES6 的modules语法编译成了 CMD 的语法,所以还需要用 browserify 之类的工具再次编译一遍。 
如果你发现 browserify 找不到 lib,可以改成 from ‘./lib’ 试试。

默认导出

大家会发现上面的写法比较麻烦,因为必须要指定一个名字。其实很多时候一个模块只导出了一个变量,根本没必要指定一个名字。 
还有一种用法叫默认导出,就是指定一个变量作为默认值导出:

  1. //------ myFunc.js ------
  2. export default function () { ... };
  3. //------ main1.js ------
  4. import myFunc from 'myFunc';
  5. myFunc();

默认导出的时候不需要指定一个变量名,它默认就是文件名。 
这里的区别不仅仅是不用写名字,而是 导出的默认值就是模块本身,而不是模块下面的一个属性,即是 import myFunc from 'myFunc’; 而不是 import {myFunc} from 'myFunc’;

命名导出结合默认导出

默认导出同样可以结合命名导出来使用:

  1. export default function (obj) {
  2. ...
  3. };
  4. export function each(obj, iterator, context) {
  5. ...
  6. }
  7. export { each as forEach };

上面的代码导出了一个默认的函数,然后由导出了两个命名函数,我们可以这样导入:

  1. import _, { each } from 'underscore';

注意这个逗号语法,分割了默认导出和命名导出

其实这个默认导出只是一个特殊的名字叫 default,你也可以就直接用他的名字,把它当做命名导出来用,下面两种写法是等价的:

  1. import { default as foo } from 'lib';
  2. import foo from 'lib';

同样的,你也可以通过显示指定 default 名字来做默认导出, 下面两种写法是一样的:

  1. //------ module1.js ------
  2. export default 123;
  3. //------ module2.js ------
  4. const D = 123;
  5. export { D as default };

仅支持静态导入导出

ES6规范只支持静态的导入和导出,也就是必须要在编译时就能确定,在运行时才能确定的是不行的,比如下面的代码就是不对的:

  1. //动态导入
  2. var mylib;
  3. if (Math.random()) {
  4. mylib = require('foo');
  5. } else {
  6. mylib = require('bar');
  7. }
  8. //动态导出
  9. if (Math.random()) {
  10. exports.baz = ...;
  11. }

为什么要这么做,主要是两点:

  1. 性能,在编译阶段即完成所有模块导入,如果在运行时进行会降低速度
  2. 更好的检查错误,比如对变量类型进行检查

各种导入和导出方式总结

总结一下,ES6提供了如下几种导入方式:

  1. // Default exports and named exports
  2. import theDefault, { named1, named2 } from 'src/mylib';
  3. import theDefault from 'src/mylib';
  4. import { named1, named2 } from 'src/mylib';
  5. // Renaming: import named1 as myNamed1
  6. import { named1 as myNamed1, named2 } from 'src/mylib';
  7. // Importing the module as an object
  8. // (with one property per named export)
  9. import * as mylib from 'src/mylib';
  10. // Only load the module, don’t import anything
  11. import 'src/mylib';

如下几种导出方式:

  1. //命名导出
  2. export var myVar1 = ...;
  3. export let myVar2 = ...;
  4. export const MY_CONST = ...;
  5. export function myFunc() {
  6. ...
  7. }
  8. export function* myGeneratorFunc() {
  9. ...
  10. }
  11. export class MyClass {
  12. ...
  13. }
  14. // default 导出
  15. export default 123;
  16. export default function (x) {
  17. return x
  18. };
  19. export default x => x;
  20. export default class {
  21. constructor(x, y) {
  22. this.x = x;
  23. this.y = y;
  24. }
  25. };
  26. //也可以自己列出所有导出内容
  27. const MY_CONST = ...;
  28. function myFunc() {
  29. ...
  30. }
  31. export { MY_CONST, myFunc };
  32. //或者在导出的时候给他们改个名字
  33. export { MY_CONST as THE_CONST, myFunc as theFunc };
  34. //还可以导出从其他地方导入的模块
  35. export * from 'src/other_module';
  36. export { foo, bar } from 'src/other_module';
  37. export { foo as myFoo, bar } from 'src/other_module';

注: 
主要参考这篇文章:http://www.2ality.com/2014/09/es6-modules-final.html

ES6详解八:模块(Module)!--各种导入导出方法的更多相关文章

  1. 详解Python模块导入方法

    python常被昵称为胶水语言,它能很轻松的把用其他语言制作的各种模块(尤其是C/C++)轻松联结在一起.python包含子目录中的模块方法比较简单,关键是能够在sys.path里面找到通向模块文件的 ...

  2. PE文件结构详解(五)延迟导入表

    PE文件结构详解(四)PE导入表讲 了一般的PE导入表,这次我们来看一下另外一种导入表:延迟导入(Delay Import).看名字就知道,这种导入机制导入其他DLL的时机比较“迟”,为什么要迟呢?因 ...

  3. [转载]python 详解re模块

    原文地址:python 详解re模块作者:Rocky 正则表达式的元字符有. ^ $ * ? { [ ] | ( ) .表示任意字符 []用来匹配一个指定的字符类别,所谓的字符类别就是你想匹配的一个字 ...

  4. 深入解析ThreadLocal 详解、实现原理、使用场景方法以及内存泄漏防范 多线程中篇(十七)

    简介 从名称看,ThreadLocal 也就是thread和local的组合,也就是一个thread有一个local的变量副本 ThreadLocal提供了线程的本地副本,也就是说每个线程将会拥有一个 ...

  5. AngularJS中module的导入导出

    关于AngularJS中module的导入导出,在Bob告诉我之前还没写过,谢谢Bob在这方面的指导,给到我案例代码. 在AngularJS实际项目中,我们可能需要把针对某个领域的各个方面放在不同的m ...

  6. ios学习--详解IPhone动画效果类型及实现方法

    详解IPhone动画效果类型及实现方法是本文要介绍的内容,主要介绍了iphone中动画的实现方法,不多说,我们一起来看内容. 实现iphone漂亮的动画效果主要有两种方法,一种是UIView层面的,一 ...

  7. sqlsever备份,还原和导入导出方法

    一:sqlsever数据库的几种备份和还原方法: 第一种:备份还原方法 1.选择要备份的数据库-任务-备份- 打开之后会看到里面有: 常规:在常规页面中我们可以看到:右下角位置有一个可以更改存储(备份 ...

  8. MySQL数据导入导出方法与工具mysqlimport

    MySQL数据导入导出方法与工具mysqlimport<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office ...

  9. oracle11g数据库导入导出方法教程

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/xinxiaoyonng/article/ ...

随机推荐

  1. idea搭建maven项目 【转发】

    为了创建maven项目可是花了我时间了,网上的教程跟我的实际情况不符合,尤其是facets .artifacts 那块.幸亏找到这篇文章没解决了我的问题,他的描述跟我的情况一模一样.这篇文章竟然来自百 ...

  2. buf.readUIntBE()

    buf.readUIntBE(offset, byteLength[, noAssert]) buf.readUIntLE(offset, byteLength[, noAssert]) offset ...

  3. 在vue项目中快速使用element UI

    推荐使用npm安装 1.安装:npm install element-ui -S 2.整体引入: 在你项目的main.js中写入: import ElementUI from 'element-ui' ...

  4. Uva 10730 Antiarithmetic?

    uva 10730 题意:给出一列数字,如果其中存在长度大于等于3的等差数列,输出no,不存在就输出yes 这道题标定了数列长度n,而且这n个数数据范围是从0到n-1,没有相同的数,这就给我们枚举提供 ...

  5. HDU - 6158 The Designer

    传送门:http://acm.hdu.edu.cn/showproblem.php?pid=6158 本题是一个计算几何题——四圆相切. 平面上的一对内切圆,半径分别为R和r.现在这一对内切圆之间,按 ...

  6. Spring 获取当前activeProfile

    WebApplicationContext wac = WebApplicationContextUtils.getWebApplicationContext(getServletContext()) ...

  7. 关于markdown(typora)的操作指南,以及导出为word格式文件插件(pandoc-2.6-windows-x86_64)的下载

    Markdown简介 插件链接文章结尾处 目录 Markdown简介1. Markdown是什么?2. 谁创造了它?3. 为什么要使用它?4. 怎么使用?4.1 标题4.2 段落4.3 区块引用4.4 ...

  8. JavaSE 学习笔记之API(二十一)

    API--- java.lang.Runtime: 类中没有构造方法,不能创建对象. 但是有非静态方法.说明该类中应该定义好了对象,并可以通过一个static方法获取这个对象.用这个对象来调用非静态方 ...

  9. WIKIOI 1319 玩具装箱

    1319 玩具装箱 题目描述 Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维 ...

  10. nyoj 108 士兵杀敌(一)

    士兵杀敌(一) 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述 南将军手下有N个士兵,分别编号1到N,这些士兵的杀敌数都是已知的. 小工是南将军手下的军师,南将军现在 ...