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 相关文章推荐
javascript 语法基础 想学习js的朋友可以看看
Dec 16 Javascript
js 省地市级联选择
Feb 07 Javascript
javascript preload&amp;lazy load
May 13 Javascript
js调试系列 源码定位与调试[基础篇]
Jun 18 Javascript
javascript事件冒泡实例分析
May 13 Javascript
JavaScript中Number.MAX_VALUE属性的使用方法
Jun 04 Javascript
JS实现浏览器状态栏显示时间的方法
Oct 27 Javascript
浅谈在js传递参数中含加号(+)的处理方式
Oct 11 Javascript
Vuex之理解Store的用法
Apr 19 Javascript
解决Vue打包之后文件路径出错的问题
Mar 06 Javascript
layui prompt 设置允许空白提交的方法
Sep 24 Javascript
vue 百度地图(vue-baidu-map)绘制方向箭头折线实例代码详解
Apr 28 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
从PHP $_SERVER相关参数判断是否支持Rewrite模块
2013/09/26 PHP
PHP利用MySQL保存session的实现思路及示例代码
2014/09/09 PHP
php实现汉字验证码和算式验证码的方法
2015/03/07 PHP
Zend Framework缓存Cache用法简单实例
2016/03/19 PHP
详解php实现页面静态化原理
2017/06/21 PHP
PHP基于socket实现的简单客户端和服务端通讯功能示例
2017/07/10 PHP
使用隐藏的new来创建对象
2011/03/29 Javascript
js+xml生成级联下拉框代码
2012/07/24 Javascript
DIV始终居中的js代码
2014/02/17 Javascript
jquery按回车键实现表单提交的简单实例
2016/05/25 Javascript
微信小程序 简单DEMO布局,逻辑,样式的练习
2016/11/30 Javascript
JavaScript数据结构之二叉树的查找算法示例
2017/04/13 Javascript
jQuery Plupload上传插件的使用
2017/04/19 jQuery
使用Vue-cli 3.0搭建Vue项目的方法
2018/06/07 Javascript
JS实现用特殊符号替换字符串的中间部分区域的实例代码
2018/07/24 Javascript
JS闭包经典实例详解
2018/12/20 Javascript
Vue框架下引入ActiveX控件的问题解决
2019/03/25 Javascript
webpack4实现不同的导出类型
2019/04/09 Javascript
nuxt配置通过指定IP和端口访问的实现
2020/01/08 Javascript
微信小程序实现时间戳格式转换
2020/07/20 Javascript
NodeJS模块Buffer原理及使用方法解析
2020/11/11 NodeJs
老生常谈python之鸭子类和多态
2017/06/13 Python
浅谈pandas用groupby后对层级索引levels的处理方法
2018/11/06 Python
浅谈python之高阶函数和匿名函数
2019/03/21 Python
Python进度条的制作代码实例
2019/08/31 Python
python输出第n个默尼森数的实现示例
2020/03/08 Python
HTML5 Web存储方式的localStorage和sessionStorage进行数据本地存储案例应用
2012/12/09 HTML / CSS
英国工具中心:UK Tool Centre
2017/07/10 全球购物
荷兰天然和有机产品网上商城:BigGreenSmile.nl
2020/07/26 全球购物
玩具公司的创业计划书
2013/12/31 职场文书
求职信的七个关键技巧
2014/02/05 职场文书
采购部部长岗位职责
2014/02/06 职场文书
五年级音乐教学反思
2014/02/06 职场文书
学校节能宣传周活动总结
2014/07/09 职场文书
七一表彰大会简报
2015/07/20 职场文书
导游词之铁岭象牙山
2019/12/06 职场文书