1
0
forked from x/volcanos

add volcanos.js

This commit is contained in:
shaoying 2019-12-07 04:53:43 +08:00
parent f412a44aea
commit 16dc9edff3
3 changed files with 109 additions and 2 deletions

1
.gitignore vendored Normal file
View File

@ -0,0 +1 @@
*.swp

View File

@ -1,2 +1,35 @@
# volcanos <!DOCTYPE html>
frontage framework <head>
<meta charset="utf-8">
<title>:volcano.md</title>
<link rel="shortcut icon" type="image/ico" href="/static/librarys/favicon.ico">
<link rel="stylesheet" type="text/css" href="/static/librarys/share.css">
<script src="/static/volcanos/volcanos.js"></script>
<script src="/static/librarys/share.js"></script>
</head>
<body>
<h1>Volcanos.js</h1>
<p>volcanos是一个前端框架。
模块化
通过建立脚本的依赖关系,按需加载相关文件,从而更加高效的组织项目文件。
<svg vertion="1.1" xmlns="http://www.w3.org/2000/svg" width="393", height="88" style="">
<rect x="4" y="26" width="123" height="36" fill="red" />
<text x="65" y="44" font-size="24" style="dominant-baseline:middle;text-anchor:middle;" fill="white" >Volcanos</text>
<rect x="135" y="26" width="123" height="36" fill="red" />
<text x="196" y="44" font-size="24" style="dominant-baseline:middle;text-anchor:middle;" fill="white" >Volcanos</text>
<rect x="266" y="4" width="123" height="36" fill="red" />
<text x="327" y="22" font-size="24" style="dominant-baseline:middle;text-anchor:middle;" fill="white" >Volcanos</text>
<rect x="266" y="48" width="123" height="36" fill="red" />
<text x="327" y="66" font-size="24" style="dominant-baseline:middle;text-anchor:middle;" fill="white" >Volcanos</text>
</svg></p>
<h2>0.1 type模块</h2>
<h2>0.2 core模块</h2>
<h2>0.3 node模块</h2>
<h2>0.4 misc模块</h2>
<h2>0.5 device模块</h2>

73
volcanos.js Normal file
View File

@ -0,0 +1,73 @@
function Volcanos(name, can, libs, cb) {var list = arguments.callee.list || [], meta = arguments.callee.meta || {
// 全局属性
path: "/static/volcanos/", index: 1,
};
can[name] || list.push({name: name, can: can, create_time: new Date()}) && (can.__proto__ = {
// 通用属性
create_time: new Date(),
name: name, help: "静态模块", load: function() {
for (var i = meta.index; i < list.length; i++) {var item = list[i];
can[item.name] = item.can, item.can.name != can.name && (item.can.name = can.name + "." + item.name);
}
meta.index = i
},
}), arguments.callee.meta = meta, arguments.callee.list = list;
if (libs && libs.length > 0) {
if (can[libs[0]]) {
// 重复加载
libs.length > 1? Volcanos(name, can, libs.slice(1), cb): cb(can);
} else {
// 加载脚本
var script = document.createElement("script");
script.src = (can.path||meta.path)+libs[0]+".js";
script.type = "text/javascript";
script.onload = function() {
can.load(), libs.length > 1? Volcanos(name, can, libs.slice(1), cb): cb(can);
}
document.body.appendChild(script);
}
} else {
typeof cb == "function" && cb(can);
}
return can
}
Volcanos("type", {help: "类型模块",
Format: function(obj) {return JSON.stringify(obj)},
List: function(obj, cb, interval, cbs) {obj = typeof obj == "string"? [obj]: (obj || [])
if (interval > 0) {
function loop(i) {if (i >= obj.length) {return kit._call(cbs)}
kit._call(cb, [obj[i], i, obj]), setTimeout(function() {loop(i+1)}, interval)
}
obj.length > 0 && setTimeout(function() {loop(0)}, interval/4)
return obj
}
var list = []
for (var i = 0; i < obj.length; i++) {
kit.Push(list, kit._call(cb, [obj[i], i, obj]))
}
return list
},
})
Volcanos("core", {help: "核心模块",
Log: function() {
},
})
Volcanos("node", {help: "节点模块",
Log: function() {
},
Split: function() {},
})
Volcanos("misc", {help: "其它模块",
})
Volcanos("device", {help: "设备模块",
isWeiXin: navigator.userAgent.indexOf("MicroMessenger") > -1,
isMobile: navigator.userAgent.indexOf("Mobile") > -1,
isIPhone: navigator.userAgent.indexOf("iPhone") > -1,
isMacOSX: navigator.userAgent.indexOf("Mac OS X") > -1,
isWindows: navigator.userAgent.indexOf("Windows") > -1,
})