1. es6 module 浏览器实现 异步静态加载 输出模块内变量接口,在运行之前就确定,此时代码还没有执行,所以不能出现动态的引入路径
2. cjs module node实现 require同步动态加载,可以出现在条件语句等动态上下文中,反正要代码执行后才知道输出
webpack等打包工具只是模拟实现了模块载入方式,最后打包在一起,并不是真正的es6和cjs,因为打包的时候代码并没有运行。
rollup适合三方库开发,扁平打包,每个模块没有函数包装,没有独立作用域,通过重命名解决变量命名冲突问题。可以做到打包时的tree-shaking
webpack适合应用开发,有运行时代码专门管理模块,每个模块有独立作用域,所以可以实现按需加载这类rollup无法实现的动态处理。