javascript 模块依赖管理的本质深入详解


Posted in Javascript onApril 30, 2020

本文实例讲述了javascript 模块依赖管理的本质。分享给大家供大家参考,具体如下:

模块模式定义

模块是'javascript'的一种设计模式,它为函数定义一个包装函数,并且该包装函数的返回值与模块的API保持一致:

function createModule() {
 function hello(name) {
 console.log(name + '帅哥你好!');
 }

 return {
 hello: hello
 }
}
// 这里调用 createModule 来创建一个模块实例
var foo = createModule();
foo.hello('fayin');

单例模块模式

仔细研究上面的模块,我们发现每次调用 createModule 都会生成一个实例,很浪费。于是我们简单的包装一下,就有了单例模块模式:

var myModule = (function createModule() {
 function hello(name) {
 console.log(name + '帅哥你好!');
 }

 return {
 hello: hello
 }
})()

// 调用方式
myModule.hello('fayin')

模块依赖管理

现代大多数模块依赖管理器本质上都是将这种模块定义封装进一个友好的API。其核心的方法可以通过下面的例子一窥究竟:

// 通过模块的单例模式来保存定义的方法
var MyModules = (function() {

 var modules = {};

 function define(name, deps, impl) {
 console.log(deps.length)
 for(var i = 0, len = deps.length; i < len; i++) {
  // deps[i] 看做是函数名
  // modules[deps[i]] 是保存在 modules 对象上的一个属性为 deps[i] 的方法
  // 每次遍历将对应的方法绑定到函数名上
  deps[i] = modules[deps[i]]

 }
 // 在modules 对象上保存方法,其函数名为 name 
 // 如函数 bar ,impl 为 bar 的函数体
 modules[name] = impl.apply(null, deps);

 console.log( modules)
 }

 function get(name) {
 return modules[name]
 }
 return {
 define: define,
 get: get
 };
})();

// 这里定义一个函数 bar,返回一个对象
MyModules.define('bar', [], function() {
 function hello(who) {
 return 'Let me introduce: ' + who;
 }
 return {
 hello: hello
 }
})

MyModules.define('foo', ['bar'], function(bar) {
 var hungry = 'hippo';

 function awesome() {
 return bar.hello(hungry).toUpperCase()
 }

 return {
 awesome: awesome
 }
})

var bar = MyModules.get('bar')
console.log(bar.hello('fay'))

var foo = MyModules.get('foo')

console.log(foo.awesome())

模块模式的缺陷

从上面的案例我们知道,这个模式是基于函数来实现的,它的优势这里不在赘述(参考jQuery),而它的缺点也非常的明显。由于函数的上下文环境是在运行时确定的,在编译期间无法确定它的依赖关系,在运行期间我们可以随意更改API,这导致基于函数的模块模式并不稳定。

而相比之下,ES6的模块API更加的稳定......

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
Jquery 点击按钮显示和隐藏层的代码
Jul 25 Javascript
jQuery弹出层始终垂直居中相对于屏幕或当前窗口
Apr 01 Javascript
jQuery的选择器中的通配符[id^='code']或[name^='code']及jquery选择器总结
Dec 24 Javascript
JavaScript基础重点(必看)
Jul 09 Javascript
js实现5秒倒计时重新发送短信功能
Feb 05 Javascript
video.js使用改变ui过程
Mar 05 Javascript
微信小程序 下拉菜单的实现
Apr 06 Javascript
React事件处理的机制及原理
Dec 03 Javascript
小程序云开发之用户注册登录
May 18 Javascript
vue-cli 3 全局过滤器的实例代码详解
Jun 03 Javascript
Vue中axios拦截器如何单独配置token
Dec 27 Javascript
javascript设计模式 ? 建造者模式原理与应用实例分析
Apr 10 Javascript
JavaScript find()方法及返回数据实例
Apr 30 #Javascript
js this 绑定机制深入详解
Apr 30 #Javascript
JS 图片压缩原理与实现方法详解
Apr 29 #Javascript
详解Vue3 Composition API中的提取和重用逻辑
Apr 29 #Javascript
浅谈Vue3 Composition API如何替换Vue Mixins
Apr 29 #Javascript
JS数组Reduce方法功能与用法实例详解
Apr 29 #Javascript
JavaScript实现放大镜效果代码示例
Apr 29 #Javascript
You might like
一条久听不愿放下的DIY森海MX500,三言两语话神奇
2021/03/02 无线电
2.PHP入门
2006/10/09 PHP
ThinkPHP快速入门实例教程之数据分页
2014/07/01 PHP
PHP利用MySQL保存session的实现思路及示例代码
2014/09/09 PHP
跟我学Laravel之配置Laravel
2014/10/15 PHP
php计算整个目录大小的方法
2015/06/01 PHP
PHP SFTP实现上传下载功能
2017/07/26 PHP
再次更新!MSClass (Class Of Marquee Scroll通用不间断滚动JS封装类 Ver 1.6)
2007/02/05 Javascript
javascript中的继承实例代码
2011/04/27 Javascript
js简单实现删除记录时的提示效果
2013/12/05 Javascript
在JavaScript中处理时间之getHours()方法的使用
2015/06/10 Javascript
jQuery实现拖拽页面元素并将其保存到cookie的方法
2016/06/12 Javascript
利用JavaScript判断浏览器类型及版本
2016/08/23 Javascript
JS判断form内所有表单是否为空的简单实例
2016/09/09 Javascript
javascript 分号总结及详细介绍
2016/09/24 Javascript
使用ReactJS实现tab页切换、菜单栏切换、手风琴切换和进度条效果
2016/10/17 Javascript
vue拦截器Vue.http.interceptors.push使用详解
2017/04/22 Javascript
jQuery实现html双向绑定功能示例
2017/10/09 jQuery
vue.js实现图书管理功能
2019/09/24 Javascript
24行JavaScript代码实现Redux的方法实例
2019/11/17 Javascript
在Vue中使用HOC模式的实现
2020/08/23 Javascript
Python基于回溯法子集树模板解决旅行商问题(TSP)实例
2017/09/05 Python
在Pycharm中调试Django项目程序的操作方法
2019/07/17 Python
django 单表操作实例详解
2019/07/30 Python
用python3读取python2的pickle数据方式
2019/12/25 Python
行政管理毕业生自荐信
2014/02/24 职场文书
学生评语大全
2014/04/18 职场文书
初中作文评语大全
2014/04/23 职场文书
学校食品安全实施方案
2014/06/14 职场文书
公司经营目标责任书
2015/01/29 职场文书
工厂清洁工岗位职责
2015/02/14 职场文书
工厂门卫岗位职责
2015/04/13 职场文书
售后服务质量承诺书
2015/04/29 职场文书
详解CSS不受控制的position fixed
2021/05/25 HTML / CSS
教你如何使用Python开发一个钉钉群应答机器人
2021/06/21 Python
如何用H5实现好玩的2048小游戏
2022/07/23 HTML / CSS