在使用 sea.js 、require.js 、 angular 的时候。
我们使用到 define 、 module(require) 的方式,定义模块,和依赖模块
下面给出 define 和 module 的简单实现。 其本质,就是往一个对象上面添加方法
var F = {}; F.define = function(str,fn){ var parts = str.split("."); var parent = this; // parent 当前模块的父模块 var i = len = 0; //如果第一个模块是模块单体对象,则移除 if(parts[0] == "F"){ parts = parts.slice(1); } //屏蔽对 define module 模块方法重写 if(parts[0] == "define" || parts[0] == "module"){ return ; } for(len = parts.length; i < len-1; i++){ //如果父模块中不存在当前模块 if(typeof parent[parts[i]] === 'undefined'){ //声明当前模块 parent[parts[i]] = {}; } //缓存下一层父模块 parent = parent[parts[i]]; } if(fn && parts[i]){ //如果给定模块方法,则绑定该模块的方法, parent[parts[i]] = fn(); } return this; } F.module = function(){ var args = [].slice.call(arguments);//复制参数 var fn = args.pop(); //获取回调 var parts = args[0] && args[0] instanceof Array ""; //依赖模块的索引 var i = 0; var len = parts.length; // 依赖模块的长度 var parent,j,jlen; //父级模块,模块路由层级索引,模块路由层级长度 while(i < len){ if(typeof parts[i] == "string"){ parent = this; //解析路由,并且屏蔽掉 F modIDs = parts[i].replace(/^F\./,"").split("."); //遍历模块层级 for( j = 0,jlen = modIDs.length; j < jlen; j++){ //迭代 父模块 parent = parent[modIDs[j]] || false; } modules.push(parent); //将模块添加到依赖列表 }else{ //直接将模块添加到依赖列表 modules.push(parts[i]); } //取下一个模块 i++; } //执行回调,将依赖的模块注入 fn.apply(null,modules); } //定义 string 模块 F.define("string",function(){ return { trim(str){ return str.replace(/^s+|\s+$/g,""); } } }); //定义 string 模块,的子模块 sub F.define("string.sub",function(){ return { low(str){ return str.toLowerCase(); } } }); console.log(F); //使用模块 F.module(["string","string.sub",document],function(str,strSub,doc){ console.log(str,strSub,doc) });
当然了,这里使用的,F 对象,实际应用中,应该写在闭包里面。不能让外界直接访问,于是有如下代码。
var Sea = (function(){ var F = {}; F.define = function(str,fn){ var parts = str.split("."); var parent = this; // parent 当前模块的父模块 var i = len = 0; //如果第一个模块是模块单体对象,则移除 if(parts[0] == "F"){ parts = parts.slice(1); } //屏蔽对 define module 模块方法重写 if(parts[0] == "define" || parts[0] == "module"){ return ; } for(len = parts.length; i < len-1; i++){ //如果父模块中不存在当前模块 if(typeof parent[parts[i]] === 'undefined'){ //声明当前模块 parent[parts[i]] = {}; } //缓存下一层父模块 parent = parent[parts[i]]; } if(fn && parts[i]){ //如果给定模块方法,则绑定该模块的方法, parent[parts[i]] = fn(); } return this; } F.module = function(){ var args = [].slice.call(arguments);//复制参数 var fn = args.pop(); //获取回调 var parts = args[0] && args[0] instanceof Array ""; //依赖模块的索引 var i = 0; var len = parts.length; // 依赖模块的长度 var parent,j,jlen; //父级模块,模块路由层级索引,模块路由层级长度 while(i < len){ if(typeof parts[i] == "string"){ parent = this; //解析路由,并且屏蔽掉 F modIDs = parts[i].replace(/^F\./,"").split("."); //遍历模块层级 for( j = 0,jlen = modIDs.length; j < jlen; j++){ //迭代 父模块 parent = parent[modIDs[j]] || false; } modules.push(parent); //将模块添加到依赖列表 }else{ //直接将模块添加到依赖列表 modules.push(parts[i]); } //取下一个模块 i++; } //执行回调,将依赖的模块注入 fn.apply(null,modules); } return { define:function(){ F.define.apply(F,arguments); }, module:function(){ F.module.apply(F,arguments); } } })(); //定义 string 模块 Sea.define("string",function(){ return { trim(str){ return str.replace(/^s+|\s+$/g,""); } } }); //定义 string 模块,的子模块 sub Sea.define("string.sub",function(){ return { low(str){ return str.toLowerCase(); } } }); console.log(Sea); //使用模块 Sea.module(["string","string.sub",document],function(str,strSub,doc){ console.log(str,strSub,doc) });
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“javascript 构建模块化开发过程解析”评论...
更新动态
2025年01月15日
2025年01月15日
- 小骆驼-《草原狼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]