通过实例解析js简易模块加载器


Posted in Javascript onJune 17, 2019

前端模块化

关注前端技术发展的各位亲们,肯定对模块化开发这个名词不陌生。随着前端工程越来越复杂,代码越来越多,模块化成了必不可免的趋势。

各种标准

由于javascript本身并没有制定相关标准(当然es6已经有了import和export),所以在模块化方面诞生了各种不同的规范。主要有AMD规范(随requirejs诞生而普及),CMD规范(随seajs的出现而普及),commonjs(主要用于node,并不适合前端)。至于以上几种规范的异同,无耻的我在这里就不多费口水了,请还不了解的亲们自行去找google爸爸。

简易模块加载器示例

G点来了!

接下来我们先来看一段建议模块加载器的示例代码:

let Module = (() => {
let module_list = {};
function define(name,rely,callback){
if (module_list[name]){
console.log("The module have already existed!")
}else{
for(let i = 0;i < rely.length;i++){
rely[i] = module_list[rely[i]];
}
module_list[name] = callback.apply(callback,rely);
}
}
function require(name){
if (module_list[name]){
return module_list[name]
}else{
console.log("There is no such module!")
}
}
let api = {
"define":define,
"require":require
};
return api;
})();

以上是加载器的实现,再来看看如何使用吧:

Module.define("test",[],()=>{
function sayHello(name){
return name+",你好啊";
}
return {
"sayHello":sayHello
}
})
Module.define("haha",[],()=>{
function gotoHZ(name){
return name+"要去杭州玩了";
}
return {
"gotoHZ":gotoHZ
}
})
Module.define("my_module",["test","haha"],(test,haha)=>{
let name = "andrew";
function sayHello2() {
let str = test.sayHello(name);
console.log(haha.gotoHZ("章炜"))
str = str + ",今天天气不错噢";
return str;
}
return {
"sayHello2":sayHello2
}
})
console.log(Module.require('my_module').sayHello2())
console.log(Module.require('test').sayHello("steve"))

在以上代码中,我们定义了三个模块,分别名为test,haha,my_module。看到这里的你,如果js基础不好,可能是一脸懵逼,脑子绕晕...先不急,让我们来看看运行的结果:

通过实例解析js简易模块加载器

结果很简单,打印了一些我们想要的信息。

代码分析

接下来我们详细来解析一下代码原理。

加载器中的几个重点,

1.dule_list

module_list是一个对象,用于存储定义的模块,以模块名:callback这样
的键值对的形式存储;

2.fine函数

然后我们定义了一个define函数,其三个参数分别为模块名、此模块依赖列表、此模块回调函数,当我们调用define函数时,首先先去检查module_list对
象中是否已经有同名模块,如果有,直接告诉用户该模块名字已被使用,如果没有,我们循环依赖列表rely,循环中的操作用于将依赖列表从名称列表转换为真正的模块列表,然后利用apply函数,将其逐个传入到定义好的callback函数中。

3.quire函数

由于我们的module_list存在于内部作用域,保证了模块的私密性,外部并不能
直接操作模块列表去读取模块,因此我们定义了一个require函数,利用闭包来读取操作相应模块

4.解析

Module.define("my_module",["test","haha"],(test,haha)=>{
let name = "andrew";
function sayHello2() {
let str = test.sayHello(name);
console.log(haha.gotoHZ("章炜"))
str = str + ",今天天气不错噢";
return str;
}
return {
"sayHello2":sayHello2
}
})

这里我们定义了my_module模块,它依赖的模块有test、haha两个模块,而在回调函数中,我们将这两个模块传入,可以看到我们能调用test模块的sayHello方法,可以调用haha模块的gotoHZ方法,至此,一个简单的模块加载器就实现了。

结语

这个简单的模块加载器只是很简化的介绍了模块加载器实现的基本原理,成熟的模块加载器当然是要复杂得多,但是原理了解了,才是最重要,不是嘛~

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js创建对象的几种常用方式小结(推荐)
Oct 24 Javascript
js的[defer]和[async]属性
Nov 24 Javascript
js实现简单随机抽奖的方法
Jan 27 Javascript
js+css实现上下翻页相册代码分享
Aug 18 Javascript
使用canvas实现仿新浪微博头像截取上传功能
Sep 02 Javascript
jquery mobile 实现自定义confirm确认框效果的简单实例
Jun 17 Javascript
在web中js实现类似excel的表格控件
Sep 01 Javascript
如何使用headjs来管理和异步加载js
Nov 29 Javascript
javascript设计模式 ? 建造者模式原理与应用实例分析
Apr 10 Javascript
nuxt静态部署打包相对路径操作
Nov 06 Javascript
Vue + ts实现轮播插件的示例
Nov 10 Javascript
CentOS 8.2服务器上安装最新版Node.js的方法
Dec 16 Javascript
如何从头实现一个node.js的koa框架
Jun 17 #Javascript
javascript定时器的简单应用示例【控制方块移动】
Jun 17 #Javascript
深入解析koa之异步回调处理
Jun 17 #Javascript
JS中数据结构与算法---排序算法(Sort Algorithm)实例详解
Jun 17 #Javascript
详解element-ui设置下拉选择切换必填和非必填
Jun 17 #Javascript
JS实现的字符串数组去重功能小结
Jun 17 #Javascript
JavaScript静态作用域和动态作用域实例详解
Jun 17 #Javascript
You might like
php中的路径问题与set_include_path使用介绍
2014/02/11 PHP
php求正负数数组中连续元素最大值示例
2014/04/11 PHP
避免Smarty与CSS语法冲突的方法
2015/03/02 PHP
Smarty环境配置与使用入门教程
2016/05/11 PHP
PHP二进制与字符串之间的相互转换教程
2016/10/14 PHP
ThinkPHP 3.2.2实现事务操作的方法
2017/05/05 PHP
PHP给前端返回一个JSON对象的实例讲解
2018/05/31 PHP
PHP中md5()函数的用法讲解
2019/03/30 PHP
PHP pthreads v3在centos7平台下的安装与配置操作方法
2020/02/21 PHP
php中加密解密DES类的简单使用方法示例
2020/03/26 PHP
js判断是否为数组的函数: isArray()
2011/10/30 Javascript
javascript学习笔记(十) js对象 继承
2012/06/19 Javascript
addEventListener和attachEvent二者绑定的执行函数中的this不相同
2012/12/09 Javascript
jquery实现加载等待效果示例
2013/09/25 Javascript
Extjs4实现两个GridPanel之间数据拖拽功能具体方法
2013/11/21 Javascript
对new functionName()定义一个函数的理解
2014/05/22 Javascript
jQuery实现复选框成对选择及对应取消的方法
2015/03/03 Javascript
jquery插件tytabs.jquery.min.js实现渐变TAB选项卡效果
2015/08/25 Javascript
iframe中子父类窗口调用JS的方法及注意事项
2015/08/25 Javascript
JS判断form内所有表单是否为空的简单实例
2016/09/09 Javascript
JS 实现Base64编码与解码实例详解
2016/11/07 Javascript
利用vue + element实现表格分页和前端搜索的方法
2017/12/25 Javascript
解决vuex刷新状态初始化的方法实现
2019/08/15 Javascript
python通过floor函数舍弃小数位的方法
2015/03/17 Python
详谈Python基础之内置函数和递归
2017/06/21 Python
在django中使用自定义标签实现分页功能
2017/07/04 Python
Pytorch实现的手写数字mnist识别功能完整示例
2019/12/13 Python
使用pymysql查询数据库,把结果保存为列表并获取指定元素下标实例
2020/05/15 Python
在pytorch中动态调整优化器的学习率方式
2020/06/24 Python
澳大利亚拥有最佳跳伞降落点和最好服务的跳伞项目运营商:Skydive Australia
2018/03/05 全球购物
美国在线旅行社:Crystal Travel
2018/09/11 全球购物
大学自我鉴定
2013/12/20 职场文书
七一党建活动方案
2014/01/28 职场文书
2015年暑假工作总结
2015/07/13 职场文书
送给教师们,到底该如何写好教学反思?
2019/07/02 职场文书
Python内置的数据类型及使用方法
2022/04/13 Python