重新捡起来代码
看一些原来用过的知识,有一种豁然开朗的感觉
类似于,考上大学以后再回头看高中的知识
原来对js模块化的认识比较浅,仅仅是能理解的程度,AMD/CMD很多面试中都问过我
在阿里妈妈实习的时候,导师跟我说过,腾讯面试的时候也问过,那个时候就真的只是知道AMD CMD一个提前加载一个按需加载
工作以后,有个领导说过,架构不是学来的,是一步步演进的
前端技术也是,知道它们如何一步步演进的,更有利于理解和合理运用。
废话不多说,以后要坚持写博客,坚持学习!
演进过程:
一:js代码都写在html文件中
二:js代码写在js文件中,在html中<script>引用
三:js文件变得原来越多,互相之间关系越来越复杂,比如jQuery必须在使用了jQuery的js文件之前引用,否则会报错,而且变量会污染全局作用域
四:js模块化,commonjs就是js模块化的规范,通过 require 方法来同步加载所要依赖的其他模块,然后通过 exports 或者 module.exports 来导出需要暴露的接口。根据这个规范,每一个文件就是一个模块,其内部定义的变量是属于这个模块的,不会对外暴露,也就是说不会污染全局变量。
五:AMD规范,AMD标准中,模块可以异步加载,并且允许指定回调函数。但是,在使用require.js的时候,我们必须要提前加载所有的依赖,然后才可以使用,而不是需要使用时再加载。
定义了下面两个API:
require([module], callback)
define(id, [depends], callback)
即通过define来定义一个模块,然后使用require来加载一个模块。 并且,require还支持CommonJS的模块导出方式。
六:CMD按需加载,sea.js,需要写加载逻辑,在用到模块的时候,再require
七:ES6模块化,export和import导出和引用模块,一个js文件是一个模块