js模块化

重新捡起来代码

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

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

原来对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

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Javascript模块化编程,已经成为一个迫切的需求。理想情况下,开发者只需要实现核心的业务逻辑,其他都可以加载...
    zhoulujun阅读 2,947评论 0 14
  • 一、函数的Rest参数和扩展 二、Promise使用 三、modules.exports和ES6 import/e...
    puxiaotaoc阅读 233评论 0 0
  • 模块 函数式 模块是实现特定功能的文件,将多个函数编写在同一个文件中就构成了一个模块,加载文件即可调用文件中的函数...
    JunChow520阅读 465评论 0 1
  • 一、CSRF是什么 CSRF全称为跨站请求伪造(Cross-site request forgery),是一种网络...
    WWWKY阅读 21,844评论 0 6
  • “早安!虽然再过半个小时就能看见你,但我想我要对你说的话不能迟过任何一分钟!”“早安,别迟到了,一会见”每天睁开眼...
    如若我似猫阅读 444评论 1 4