美文网首页
js模块化

js模块化

作者: 小吃麻麻 | 来源:发表于2019-04-01 11:14 被阅读0次

    重新捡起来代码

    看一些原来用过的知识,有一种豁然开朗的感觉

    类似于,考上大学以后再回头看高中的知识   

    原来对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文件是一个模块

    参考https://www.cnblogs.com/zhuzhenwei918/p/7426904.html

    相关文章

      网友评论

          本文标题:js模块化

          本文链接:https://www.haomeiwen.com/subject/cpalbqtx.html