1: 为什么要使用模块化?
前端开发从最开始的嵌入script标签实现特效,到现在js得到重视应用逐渐广泛起来,前端项目越来越复杂,开发工作需要一个团队分工协作、进度管理、单元测试等等。然而,JavaScript却没有为组织代码提供任何明显帮助,甚至没有类的概念,更不用说模块(module)了。Javascript模块化编程,已经成为一个迫切的需求。理想情况下,开发者只需要实现核心的业务逻辑,其他都可以加载别人已经写好的模块。引入模块化开发能解决命名冲突,避免污染全局变量;更有效的管理文件间的依赖。提高代码可读性;代码解耦提高复用性。
2: CMD、AMD、CommonJS 规范分别指什么?有哪些应用
Commonjs:用于服务器端模块化,有一个全局性方法require(),用于加载模块。定义模块接口使用module.exports对象。著名的应用是Nodejs。commonjs是同步加载,这对服务器端不是一个问题,因为所有的模块都存放在本地硬盘,可以同步加载完成,等待时间就是硬盘的读取时间。
AMD:异步模块定义,浏览器端的模块化开发规范。由于不是JavaScript原生支持,所以使用AMD规范进行页面开发需要用到对应的库函数RequireJS。实际上AMD规范是 RequireJS 在推广过程中总结出的模块定义规范。它采用异步方式加载模块,模块的加载不影响它后面语句的运行。所有依赖这个模块的语句,都定义在一个回调函数中,等到加载完成之后,这个回调函数才会运行。
加载模块requirejs()语法:require([module], callback) 第一个参数[module],是一个数组,里面的成员就是要加载的模块;第二个参数callback,则是加载成功之后的回调函数。
定义模块define()语法:define(id?,[dependencies],factory)第一个参数模块名称(可选),第二个参数当前所定义模块的依赖(可选),第三个参数工厂函数定义模块初始化执行的函数或对象,为函数时仅执行一次,为对象时此对象为模块的输出值。
CMD:通用模块定义,是seajs在推广过程中总结出的模块定义规范。AMD推崇依赖前置。,CMD推崇依赖就近。