最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

JavaScript模块化思想之CommonJS、AMD、CMD、UMD

来源:懂视网 责编:小采 时间:2020-11-27 20:31:41
文档

JavaScript模块化思想之CommonJS、AMD、CMD、UMD

JavaScript模块化思想之CommonJS、AMD、CMD、UMD:我所了解的三种模块加载方式分别是CommonJS、AMD和CMD网上关于这三种模块加载方式讲解的文章很多,我就简单的做个介绍,如果想深入了解一下可以去网上查阅一下相关的资料。(1)CommonJS在CommonJS中,一个单独的文件就是一个模块。被调用模块内使用expo
推荐度:
导读JavaScript模块化思想之CommonJS、AMD、CMD、UMD:我所了解的三种模块加载方式分别是CommonJS、AMD和CMD网上关于这三种模块加载方式讲解的文章很多,我就简单的做个介绍,如果想深入了解一下可以去网上查阅一下相关的资料。(1)CommonJS在CommonJS中,一个单独的文件就是一个模块。被调用模块内使用expo

我所了解的三种模块加载方式分别是CommonJS、AMD和CMD

网上关于这三种模块加载方式讲解的文章很多,我就简单的做个介绍,如果想深入了解一下可以去网上查阅一下相关的资料。

(1)CommonJS

在CommonJS中,一个单独的文件就是一个模块。被调用模块内使用exports暴露接口,调用模块使用require调用暴露出来的接口。

示例如下:

// student.js
// 私有变量
var a = 123;
function add(student) {
 console.log('Add student:' + student);
}
// exports对象上的方法和变量是外部可访问的
exports.add = add;

1 // 使用require加载student.js模块2 var student = require('./student.js');

CommonJS加载模块是“同步”的,也就是说,如果我们要调用被调用模块中的公共方法和变量,一定要等被调用模块加载完毕后才可以。用于服务端的NodeJS就采用的CommonJS来管理模块。但是在浏览器端,同步加载会因为收到网络环境的影响存在很大的不确定性,所以CommonJS不适合于浏览器端。

如果在浏览器环境下想要从服务器加载模块,就必须使用“异步”的方式。所以就出现了AMD和CMD解决方案。

(2)AMD(Asynchromous Module Definition)

requireJS就是一种使用AMD异步加载模块的管理插件。AMD模块支持对象,函数,构造器,字符串,JSON等各种类型的模块。

AMD规范使用define方法定义模块:

//define(param1,param2) 通过define方法定义模块
//@param1: 数组,元素为引入的依赖模块
//@param2: 回调函数,通过形参传入依赖
define(['firstModule','secondModule'],function(firstModule,secondModule){
 function foo(){
 firstModule.test();
 }
 // 暴露foo()
 return {foo:foo};
});

同时,AMD允许使用define方法定义模块是兼容CommonJS规范,可以使用require和exports。

define(function(require,exports,module){
 var reqModule = require("./firstModule");
 reqModule.test();

 exports.pubPort = function(){
 // 函数体
 }
});

(3)CMD

CMD和AMD的区别主要体现在对依赖模块的执行时机上,AMD是“依赖前置”。主张提前加载所需模块,CMD是“依赖就近”。也就是可以用到的时候再加载。有点类似于Java中的“饿汉模式”和“懒汉模式”。

从requireJS 2.0开始,也可以延迟加载了。

举个栗子:

// AMD——依赖前置
define(['./a','./b'],function(a,b){
 //提前声明要依赖的模块
});

// CMD
define(function(require,exports,module){
 //依赖可以就近写
 var a = require('./a');
 a.test();

 //软依赖
 if(status){
 var b = require('./b');
 b.test();
 }

这里有个名词叫软依赖,我个人理解软依赖就是不一定依赖,硬依赖就是一定会依赖的模块,软依赖就是需要才依赖,不需要就不依赖,根据status判断。

(4)UMD

UMD——Universal Module Definition,通用的模块定义

UMD等于CommonJS加上AMD。UMD的工作其实就是做了一个判断:

- 先判断当前环境对NodeJs支持的模块是否存在,存在就用Node.js模块模式(exports)。

- 如果不支持,就判断是否支持AMD(define),存在就使用AMD方式加载。

感觉自己对UMD还不是很理解,不知道具体应该怎么去用。还是继续去了解了解。加油!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

JavaScript模块化思想之CommonJS、AMD、CMD、UMD

JavaScript模块化思想之CommonJS、AMD、CMD、UMD:我所了解的三种模块加载方式分别是CommonJS、AMD和CMD网上关于这三种模块加载方式讲解的文章很多,我就简单的做个介绍,如果想深入了解一下可以去网上查阅一下相关的资料。(1)CommonJS在CommonJS中,一个单独的文件就是一个模块。被调用模块内使用expo
推荐度:
标签: CMD 思想 js
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top