m3m4加载器的优化版m3m4-v1.1
m3m4加载器的优化版m3m4-v1.1
/*
//1、以$开头的模块名,表示服务,服务只会执行一次,它可以有自己的方法。比如cookie就是一个服务
//例如:console.log("root");只会执行一次
define("$root",[function(){
console.log("root");
return "root"
}])
//2、非$开头的表示普通模块,普通模块每次调用的时候都会执行
//例如:console.log("userList");每次都会执行
define("userList",["$root",function($root){
console.log($root);
console.log("userList");
return "userList"
}])
//3、存在 $callback 表示异步回调模块,$callback将返回异步的数据
define("sync1",["$root","$callback",function(a,callback){
console.log(22)
setTimeout(function(){
callback("1 sync")
},1000)
}])
require("sync1",function(sync1){
console.log(sync1);//将输出结果:1 sync
})
* */
(function($){
var baseModels={}
var baseLoaded={}
var baseCache={}
function define(name,args,base){
if(base){
baseLoaded[name]=true
baseCache[name]=args
}else{
baseModels[name]=args
}
}
function require(name,callback){
var models=Object.create(baseModels)
var curCache=Object.create(baseCache)
var curLoaded=Object.create(baseLoaded)
var self={
version:"m3m4-v1.1"
}
function curRequire(name,callback){
//从全局中返回
if(/^\$/.test(name)&&baseLoaded[name]){
callback(baseCache[name])
return
}
//返回结果
if(curLoaded[name]){
callback(curCache[name])
//设置全局
if(/^\$/.test(name)){
baseCache[name]=curCache[name]
baseLoaded[name]=curLoaded[name]
}
return
}
var next=function(){
curRequire(name,callback)
}
//获取模块长度
var args=models[name]
var func=args[args.length-1]
var len=args.length-1
var dataArr=[]
//过滤 $callback
var sync=args.indexOf("$callback")
if(sync!=-1){
dataArr[sync]=function(back){
curCache[name]=back
curLoaded[name]=true
next()
}
if(--len==0){
func.apply(self,dataArr)
return;
}
}
if(len==0){
curCache[name]=func.apply(self,dataArr)
curLoaded[name]=true
next()
}else{
for(var i=0;i<args.length-1;i++){
if(i==sync)continue;
(function(n,model){
curRequire(model,function(data){
dataArr[n]=data
if(--len==0){
if(sync!=-1){
func.apply(self,dataArr)
}else{
curCache[name]=func.apply(self,dataArr)
curLoaded[name]=true
next()
}
}
})
})(i,args[i])
}
}
}
//Api兼容写法
if(Object.prototype.toString.call(name)!="[object Array]"){
models["app"]=Array.prototype.slice.call(arguments)
}else{
models["app"]=name
}
curRequire("app",function(){})
}
$.m3m4=function(func){
func(define,require)
};
$.define=define;
$.require=require;
})(typeof window!="undefined"?window:global)
demo
m3m4(function(define,require){
//定义模块
define("user1",["req",function(req){
return req
}])
//路由1
define("req",["$callback",function($callback){
setTimeout(function(){
$callback({
url:"user1.html"
})
},1000)
}])
//执行
require("user1",function(user1){
console.log(user1)
})
//路由2
define("req",["$callback",function($callback){
setTimeout(function(){
$callback({
url:"user2.html"
})
},100)
}])
//执行
require("user1",function(user1){
console.log(user1)
})
})
m3m4加载器的优化版m3m4-v1.1的更多相关文章
- js前端模块化之加载器原理解析(一)
先来说一下前端模块化的价值:引用模块此处有详细的介绍,可以自行前往观看. 一.总结如下优点: (1)解决命名冲突(2)烦琐的文件依赖(3)模块的版本管理(4)提高可维护性(5)前端性能优化(6)跨环境 ...
- 构建服务端的AMD/CMD模块加载器
本文原文地址:http://trock.lofter.com/post/117023_1208040 . 引言: 在前端开发领域,相信大家对AMD/CMD规范一定不会陌生,尤其对requireJS. ...
- C编译器、链接器、加载器详解
摘自http://blog.csdn.net/zzxian/article/details/16820035 C编译器.链接器.加载器详解 一.概述 C语言的编译链接过程要把我们编写的一个c程序(源代 ...
- js模块化/js模块加载器/js模块打包器
之前对这几个概念一直记得很模糊,也无法用自己的语言表达出来,今天看了大神的文章,尝试根据自己的理解总结一下,算是一篇读后感. 大神的文章:http://www.css88.com/archives/7 ...
- 《你必须知道的.NET》读书实践:一个基于OO的万能加载器的实现
此篇已收录至<你必须知道的.Net>读书笔记目录贴,点击访问该目录可以获取更多内容. 一.关于万能加载器 简而言之,就是孝顺的小王想开发一个万能程序,可以一键式打开常见的计算机资料,例如: ...
- 小矮人Javascript模块加载器
https://github.com/miniflycn/webkit-dwarf 短小精悍的webkit浏览器Javascript模块加载器 Why 我们有许多仅基于webkit浏览器开发的应用 无 ...
- RequireJS 是一个JavaScript模块加载器
RequireJS 是一个JavaScript模块加载器.它非常适合在浏览器中使用, 它非常适合在浏览器中使用,但它也可以用在其他脚本环境, 就像 Rhino and Node. 使用RequireJ ...
- JS框架设计之加载器所在路径的探知一模块加载系统
1.要加载一个模块,我们需要一个URL作为加载地址,一个script作为加载媒介,但用户在require是都用ID,我们需要一个将ID转换为URL的方法,思路很简单,强加个约定,URL的合成规则是为: ...
- How Tomcat Works 读书笔记 八 加载器 上
Java的类加载器 具体资料见 http://blog.csdn.net/dlf123321/article/details/39957175 http://blog.csdn.net/dlf1233 ...
随机推荐
- Django--初始化
1.Django介绍 它是一个WEB框架 Django--大而全 tornado.flask--小而精 2.Django安装 https://www.djangoproject.com/downloa ...
- WCF项目问题1-找不到类型“WCFService.Service1”,它在 ServiceHost 指令中提供为 Service 特性值,或在配置元素 system.serviceModel/serviceHostingEnvironment/serviceActivations 中提供。
找不到类型“WCFService.Service1”,它在 ServiceHost 指令中提供为 Service 特性值,或在配置元素 system.serviceModel/serviceHosti ...
- Ref 和out
out 关键字会导致参数通过引用来传递.这与 ref 关键字类似,不同之处在于 ref 要求变量必须在传递之前进行初始化.若要使用 out 参数,方法定义和调用方法都必须显式使用 out 关键字.例如 ...
- Instruments Tutorial for iOS: How To Debug Memory Leaks【转】
If you're new here, you may want to subscribe to my RSS feed or follow me on Twitter. Thanks for vis ...
- Java中方法next()和nextLine()的区别
原创 Java中Scanner类中的方法next()和nextLine()都是吸取输入台输入的字符,区别: next()不会吸取字符前/后的空格/Tab键,只吸取字符,开始吸取字符(字符前后不算)直到 ...
- ComicEnhancerPro 系列教程二十:用“文件比较”看有损、无损
作者:马健邮箱:stronghorse_mj@hotmail.com 主页:http://www.comicer.com/stronghorse/ 发布:2017.07.23 教程二十:用“文件比较” ...
- 父级(display:none)隐藏时,子节点的高度获取。
当父节点display:none的时候,子节点的高度是0获取不到. 解决办法:用visibility替换display就可以了.
- NSLocale 本地化信息
前言 NSLocale 类返回本地化信息,主要体现在"语言"和"区域格式"这两个设置项. 1.NSLocale 本地化信息的创建 // 用标示符创建 NSLoc ...
- MySQL学习笔记(一):查询
查询实例: 1.创建数据库并使用: create database school; use school; 2.创建表并插入内容: create table student( Sno char(9) ...
- linux安装配置阿里云的yum源和python3
一.yum源理解 yum源仓库的地址 在/etc/yum.repos.d/,并且只能读出第一层的repo文件 yum仓库的文件都是以.repo结尾的 二.下载阿里云的.repo仓库文件 ,放到/etc ...