ES6模块和CommonJS、AMD本质区别思考

CommonJS和AMD本质上是用一个全局变量定义了一个命名空间

以sea.js为例,各个模块输出一个对象,然后这个对象挂载在seajs.cache属性下,各个模块作为一个对象存在。

而ES6模块则不是,模块未被引用时,不会存在该模块对象。

CommonJS和AMD是运行时加载,ES6模块是编译时加载

这个区别能解释上一个区别,这也是二者区别最本质的根源。

CommonJS和AMD要加载一个模块必须先让模块执行(查看网路能看到加载对应的js文件),而ES6在编译时就完成了加载。

this关键字的区别

ES6模块中顶层this指向undefined;

CommonJS和AMD中顶层this指向模块本身;

 

posted @ 2017-10-27 16:29  庚午月圆人  阅读(759)  评论(0编辑  收藏  举报