js模块化之模块依赖处理
2015-12-18 20:39
281 查看
javascript中模块依赖处理
在javascript模块化处理模式,为处理模块间的依赖,多个js库提出了各自的模块依赖处理模式。而且功能越来越复杂,模块文件越来越多,我们需要时刻小心模块之间的依赖。ES6 模块中模块依赖处理
比如:import MyModule from ‘./MyModule.js’;
CommonJS中模块依赖处理
var MyModule = require(‘./MyModule.js’);AMD中模块依赖处理
define([‘./MyModule.js’], function (MyModule) {});
===========
著作权归作者所有。
商业转载请联系作者获得授权,非商业转载请注明出处。
作者:李翌
链接:http://www.zhihu.com/question/20342350/answer/24718689
来源:知乎
假设你对CMD、AMD还没有认识,可以移步这里:
CMD标准:https://github.com/cmdjs/specification/blob/master/draft/module.md
AMD标准:https://github.com/amdjs/amdjs-api/blob/master/AMD.md
两个类库在模块和factory的书写上其实无太大差异,差异在于模块的加载factory函数的执行。
区别:
1. 对于依赖的模块,AMD 是提前执行,CMD 是延迟执行。不过 RequireJS 从 2.0 开始,也改成可以延迟执行(根据写法不同,处理方式不同)。CMD 推崇 as lazy as possible.
2. CMD 推崇依赖就近,AMD 推崇依赖前置。看代码:
// CMD define(function(require, exports, module) { var a = require('./a') a.doSomething() // 此处略去 100 行 var b = require('./b') // 依赖可以就近书写 b.doSomething() // ... })
// AMD 默认推荐的是 define(['./a', './b'], function(a, b) { // 依赖必须一开始就写好 a.doSomething() // 此处略去 100 行 b.doSomething() // ... })
虽然 AMD 也支持 CMD 的写法,同时还支持将 require 作为依赖项传递,但 RequireJS 的作者默认是最喜欢上面的写法,也是官方文档里默认的模块定义写法。
3. AMD 的 API 默认是一个当多个用,CMD 的 API 严格区分,推崇职责单一。比如 AMD 里,require 分全局 require 和局部 require,都叫 require。CMD 里,没有全局 require,而是根据模块系统的完备性,提供 seajs.use 来实现模块系统的加载启动。CMD 里,每个 API 都简单纯粹。
相关文章推荐
- 深入理解javascript之typeof和instanceof
- js基础2-深入理解javascript之typeof和instanceof
- Javascript 那些事-开篇
- ArcGIS JavaScript API 4.0 beta3 新特性
- javascript 涉及float的精确加减乘除运算
- 对javascript匿名函数的理解
- javascript大神修炼记(5)——OOP思想(封装)
- jstree的checkbox实例+详解
- javascript iframe 操作(一)
- 高效率去掉js数组中重复项
- Ext.js5的表格插件—checkbox/编辑等常见需求(15)
- JavaScript Cookies
- javascript制作验证码
- package.json依赖管理dependencies中 ^ 和 ~ 的区别
- Ext.js5的表格插件—展开和冻结和Ext.XTemplate(14)
- 摘抄的一些js
- 用JavaScript动态加载CSS和JS文件
- js 创建对象的三种方式——工厂模式、构造函数模式、原型模式
- jsp实现ajax的一个例子
- JS设置cookie,删除cookie