前端模块化
关注前端技术发展的各位亲们,肯定对模块化开发这个名词不陌生。随着前端工程越来越复杂,代码越来越多,模块化成了必不可免的趋势。
各种标准
由于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基础不好,可能是一脸懵逼,脑子绕晕...先不急,让我们来看看运行的结果:
结果很简单,打印了一些我们想要的信息。
代码分析
接下来我们详细来解析一下代码原理。
加载器中的几个重点,
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方法,至此,一个简单的模块加载器就实现了。
结语
这个简单的模块加载器只是很简化的介绍了模块加载器实现的基本原理,成熟的模块加载器当然是要复杂得多,但是原理了解了,才是最重要,不是嘛~
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
js,模块加载器
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]