//-----当前仓库版本号
= "0.2";
//-----当前仓库名称
= "StdJS";
//-----当前仓库git地址
= "/stdjs/SourceRepository";
//-----当前仓库最新版本代码源地址,以下地址是根据当前路径和上面的版本号判断的
= (location + "").between(0,(location + "").lastIndexOf("/") + 1) + ;
//-----
("StdJS",);
body{
font-family: Lato,"Open Sans",Arial,"Hiragino Sans GB","Microsoft YaHei",STHeiti,"WenQuanYi Micro Hei",SimSun,sans-serif;
font-size: 13px;
margin: 0;
color: #474442;
background: #4C89AE;
}
h1{
display: inline-block;*display: inline;*zoom: 1;
font-size: 36px;
margin: 0;
padding: 20px 0 20px 60px;
text-shadow: 2px 4px 0 #396884;
text-align: center;
color: white;
background-image: url("");
background-repeat: no-repeat;
background-position: 0 24px;
}
h2{
font-size: 21px;
margin: 0;
padding: 10px 0 30px 0;
text-align: center;
text-shadow: 1px 2px 0 #30576F;
}
h3{
font-size: 32px;
margin: 10px 0 20px;
padding: 10px 0 10px 0;
text-align: center;
letter-spacing: 2px;
color: #28A0DA;
}
/*
* header
*/
.header{
font-size: 16px;
height: 56px;
text-align: center;
text-shadow: 1px 2px 0 #3B6C89;
border-bottom: 1px solid #3D6E8C;
background-color: #4A87AB;
}
.header > ._location{
display: inline-block;*display: inline;*zoom: 1;
text-decoration: none;
margin: 0 20px 0 20px;
height: 53px;
line-height: 50px;
border-top: 3px solid transparent;
color: #E8E8E8;
outline: none;
cursor: pointer;
transition: color 0.2s,border-color 0.2s;
}
.header > ._location:hover{
color: white;
}
.header > ._location.selected{
color: #96DBFF;
border-color: #96DBFF;
}
.header.__gray__{
background-color: #D9D5D3;
border-bottom-color: #B5B0AD;
text-shadow: 0 1px 0 #E1DAD6;
}
.header.__gray__ > ._location{
color: #474442;
}
.header.__gray__ > ._location.selected{
color: #238EC1;
border-color: #28A0DA;
}
/*
* main
*/
.main{
background: #4C89AE;
padding: 15px 0 50px 0;
text-align: center;
}
.main > ._description{
font-size: 16px;
width: 900px;
margin: 0 auto;
color: white;
}
.main > ._description > p{
line-height: 2em;
margin-bottom: 30px;
}
/*
* addresses
*/
.addresses{
background: #427797;
color: white;
padding: 25px 0 50px 0;
}
.addresses input{
font-family: Lato,"Open Sans",Arial,"Hiragino Sans GB","Microsoft YaHei",STHeiti,"WenQuanYi Micro Hei",SimSun,sans-serif;
font-size: 13px;
height: 40px;
width: 590px;
margin: 8px 0 8px 0;
padding: 0 5px 0 5px;
border: 2px solid #5FABD9;
color: white;
background: #427797;
transition: background 0.2s,border-color 0.2s;
}
.addresses input:focus{
border-color: #86D5FF;
background: #4781A4;
}
.addresses > ._row{
width: 600px;
margin: 8px auto 25px auto;
}
.addresses > ._row > ._title a{
font-style: italic;
font-size: 14px;
margin-bottom: 4px;
text-decoration: none;
color: white;
text-shadow: 0 1px 0 #134F6C;
}
.addresses > ._row > ._title a:hover{
text-decoration: underline;
}
/*
* example
*/
.example{
background: #EEF6FC;
position: relative;
padding: 20px 10px 20px 10px;
}
.example pre{
font-family: "Source Code Pro";
font-size: 14px;
margin: 0 auto;
padding:20px;
width: 860px;
}
/*
* footer
*/
.footer{
padding: 20px 0 20px 0;
background: #4C89AE;
}
.footer > ._links{
width: 900px;
margin: 0 auto;
}
.footer > ._links > a{
display: inline-block;*display: inline;*zoom: 1;
font-size: 14px;
padding: 20px 0 20px 0;
width: 24%;
color: #C2E9FF;
text-decoration: none;
text-align: center;
transition: all 0.2s;
}
.footer > ._links > a:hover{
color: white;
text-decoration: underline;
}
/*
* resources
*/
.resources{
width: 80%;
margin: 10px auto 50px auto;
border-collapse:collapse;
background: white;
border: 1px solid #3D6E8C;
}
.resources td{
padding: 3px 5px 3px 5px;
}
.resources thead > tr{
font-size: 14px;
height: 35px;
text-align: center;
font-style: italic;
margin-bottom: 4px;
text-decoration: none;
background: #4A87AB;
color: white;
}
.resources thead > tr > td{
border: 1px solid #3D6E8C;
}
.resources tbody > tr{
border-right: 1px solid #C1C1C1;
}
.resources tbody > tr > td{
font-size: 13px;
height: 30px;
border-right: 1px solid #C1C1C1;
border-bottom: 1px solid #C1C1C1;
}
/*
* packages
*/
.packages{
margin: 0 auto;
background: #D9D5D3;
border-top: 1px solid #E1DAD6;
}
/********* screen ***********/
@media only screen and (max-width: 1024px){
.resources{
width: 98%
}
}
仓库首页
仓库资源
包管理
Std Source Repository
Std Source Repository (Std代码仓库) 是StdJS用于管理代码而提供的一个代码存储仓库,仓库中可以有
任意数量以及任意类型的代码包,每个包都有独立的唯一名称,仓库中包含的包仅仅只会在需要的时候才会被载入.
这解决了js开发过程中的代码部署,以及代码复用,和其他的一系列繁琐的维护过程.
其中仓库中的包是可以任意定制的(添加,删除,修改) ,并且该页面上提供了一个在线版的包维护和构建工具(见顶部包管理),
你可以通过git将该仓库克隆到本地,放置到你自己的项目当中,或者创建一个完全属于自己的仓库地址,无论怎么样,
在项目中使用时候,只需要使用方法引入正确的地址即可,非常简单.
如果你已经将该仓库克隆到了你自己的服务器中,以及完成了自己代码仓库的包配置,并且打算公开这个代码仓库,那么请将上面的git地址修改为你自己的地址,
同时请尽量不要删除当前页面.
LATEST VERSION :
当前代码仓库的Git地址:
当前的代码仓库代码源地址:
常见的用法
/*
* 引入代码仓库,注意仓库名称StdJS,区分大小写
* 仓库中的包可以为任意数量,只有在代码引入包的时候,该包才会被真正载入
*/
("","");
/*
* 使用仓库中的包,例如
* 包含多个包的情况下可以使用数组,例如["",""]
* 只有在的包载入完毕之后托管的函数才会被执行.
*/
("",function(){
("MessageBox").information("test");
});
(function(){
("MessageBox").information("MessageBox package loaded");
});
/*
* 如果要单独执行一个函数,但是需要使用某个包,可以这样创建函数
* 被引入的包将会被自动缓存起来,第二次执行函数时候将会跳过加载包的步骤
*/
var func1 = (function(){
// code...
},{
packages:[""]
});
/*
* 在 主函数触发之前载入某个包,还可以这样写
*/
((function(){
("Notify").success("");
},{
packages:[""]
}));
(function(){
var exampleElem = ("#home_example");
var exampleText = ().replace(/\"([^\"]*)\"/g, function(word){
return "" + word + "";
}).replace(/function/g, function(word){
return "" + word + "";
}).replace(/\/\*([\s\S]*?)\*\//g, function(word){
return "" + word + "";
}).replace("",).replace(
"",
);
(exampleText);
})();
包名称版本依赖包文档地址包描述
- 包名称
- 版本
- 依赖包
- 文档地址
- 描述
文件列表:
#each files?>
$value?>
/each?>
//-------全局只需要设置一次仓库源地址
("=repositoryName?>","=latestVersionAddress?>");
//-------用等方法载入包
("=packageName?>",function(){
//.......代码
})






(function(){
var dom_header = (".header");
var packages = {};
var lastPassword = "";
var skipPassword = false;
var messager = ({
static:{
/*
* text window
*/
textWindow:(function(title,text){
("Window",{
width:800,
height:600,
modal:true,
minimizable:false,
title:title,
layout:{
ui:"VBoxLayout",
items:[{
ui:"CodeMirror",
mode:"javascript",
lineNumbers:true,
value:text
}]
}
})
},{
packages:["","[mode='javascript']"]
}),
/*
* example
*/
example:(function(packageName,repositoryName,address){
("MessageBox").information(("grid_example").render({
packageName:packageName,
repositoryName:repositoryName,
latestVersionAddress:address
}))
},{
packages:[""]
}),
/*
* delete package
*/
deletePackage:(function(callback){
("MessageBox").confirm("确定要删除选中的包吗?对应的文件也将会被删除,该操作不可恢复.","提示",callback)
},{
packages:[""]
}),
/*
* connect error
*/
connectError:(function(){
("Notify").error({
text:"无法连接到12444端口失败,可能是 未运行.
请尝试到服务器中以 node ./ 方式启动服务端.
" +
"如果已经启动服务端还是出现这个错误
则当前浏览器不支持ajax Access-Control-Allow-Origin 跨域请求",
title:"发生错误",
timeout:"8s"
});
},{
packages:[""]
}),
/*
* save success
*/
saveSuccess:(function(){
("Notify").success({
title:"成功",
text:" 和 文件保存成功",
timeout:"2s"
});
},{
packages:[""]
}),
/*
* save error
*/
saveError:(function(text){
("Notify").error({
text:"保存失败,服务器返回信息:
" + text,
title:"发生错误",
timeout:"8s"
});
},{
packages:[""]
}),
/*
* package duplicate
*/
packageDuplicate:(function(packageName){
("MessageBox").information("包: [" + packageName + "] 已经存在,不能重复添加.")
},{
packages:[""]
})
}
});
var mainModule = ({
static:{
/*
* stringify
*/
stringify:function(jsonObject){
(jsonObject,function(name,data){
if(isObject()){
(,function(name,data){
= + "";
= !!;
});
}
});
return (jsonObject,null,4);
},
/*
* save
*/
save:function(password,code){
({
url:"http://" + ().hostName + ":12444/save",
type:"post",
data:{
version:,
password:lastPassword = password,
index:code,
packages:(packages)
},
error:,
success:function(text){
if(text == "0"){
();
skipPassword = true;
}else{
(text);
}
}
});
}
},
private:{
/*
* loading
*/
loading:false,
/*
* packages loaded
*/
packagesLoaded:false,
/*
* packages grid
*/
packagesGrid:null,
/*
* packages page loaded
*/
packagesPageLoaded:false,
/*
* current page
*/
currentPage:"page_home"
},
initialize:{
/*
* init document state
*/
initDocumentState:function(){
({
append:function(){
("wait");
},
complete:function(){
(null);
}
});
},
/*
* init router
*/
initRouter:function(){
var that = this;
//------ ie fix
if(!("onhashchange" in window)){
var currentHash = ;
setInterval(function(){
if( !== currentHash){
currentHash = ;
(window).emit("hashchange");
}
},100);
}
/*
* add hash change event listener
*/
(window).on("hashchange",function(){
var hash = ;
var changeTheme = false;
if(hash === "#page_resource"){
();
}else if(hash === "#page_packages"){
changeTheme = true;
();
}else if(hash !== "#page_home"){
return;
}
dom_header.toggleClass("__gray__",changeTheme);
("#"+that._currentPage).hide();
("#"+(that._currentPage = (1))).show();
(">._location.selected",dom_header).removeClass("selected");
(">._location[href='#"+that._currentPage+"']",dom_header).addClass("selected");
});
/*
* check current url hash
*/
if( !== ""){
(window).emit("hashchange")
}
}
},
protected:{
/*
* load packages
*/
loadPackages:function(callback){
var that = this;
if(that._loading){
return;
}
if(that._packagesLoaded){
return callback(packages);
}
(that._loading = true) && ( + "/",function(data){
that._loading = false;
that._packagesLoaded = true;
callback((packages = data));
});
},
/*
* show resource page
*/
showResourcePage:function(){
(function(data){
var tbody = ("#resources > tbody").clear();
(data,function(packageName,packageValue){
(newDom("tr").append([
newDom("td").html(packageName),
newDom("td").html(),
newDom("td").html(isArray() ? (' ') : ),
newDom("td").append(
newDom("a").html().attr({
href:,
target:"_blank"
})
),
newDom("td").html()
]));
});
});
},
/*
* show packages page
*/
showPackagesPage:(function(){
var that = this;
var dom = ("#packages");
var resize = function(){
((window).height() - dom_header.outerHeight() - 1);
};
if(that._packagesPageLoaded){
resize();
().update();
return;
}
var layout = resize() || ("VBoxLayout",{
paddingTop:3
});
(window).on("resize",function(){
if(that._currentPage === "page_packages"){
resize() || ()
}
});
that._packagesGrid = ("Grid")[0];
that._packagesGrid.rowContextMenu({
items:[
("addPackage"),
("editPackage"),
("deletePackage"),
{ui:"sep"},
("reload"),
("showExample")
]
});
that._packagesGrid.on("rowEvent",function(type){
if(type === "dblclick"){
("editPackage").call();
}
});
(function(packages){
(packages,function(name,data){
(name,data);
});
});
that._packagesPageLoaded = true;
},{
delay:1,
packages:["","","",""]
})
},
public:{
/*
* update default values
*/
updateDefaultValue:function(){
("#git_address").value().prevSibling().get(0).attr("href",);
("#source_address").value().prevSibling().get(0).attr("href",);
(".addresses").on("click","input",function(){
()
});
},
/*
* build index code
*/
buildIndexCode:function(){
var code = '("'++'",function(){';
var codeMap = {at:3,func:{},variable:{}};
var analysis = {paths:{}, basics:{}};
var formatUrl = function(file){
var url = (file);
var text = file;
if( === "css"){
= ;
text = '"' + escape(()) + '"+C';
}else if( === "js"){
= ;
text = '"' + escape(()) + '"+B';
}else{
return '"' + escape(text) + '"';
}
return text;
};
code += "var B='.js',C='.css';function A(f,b,a){return {files:f,basics:b,attr:a}}";
(packages,function(name,config){
for(var i=-1;i>=0;i--){
var fileAddress = [i].trim();
if(isEmpty(fileAddress)){
(i);
continue;
}
var url = (fileAddress);
= "";
url = ();
if(isEmpty() === ""){
continue;
}
if(!(url in )){
[url] = 0;
}else{
[url]++;
}
}
for(i=-1;i>=0;i--){
var packageName = [i].trim();
if(isEmpty(packageName)){
(i);
continue;
}
if(!(packageName in )){
[packageName] = 0;
}else{
[packageName]++;
}
}
});
(,function(path,pathNumber){
if(pathNumber > 1){
var name = (++);
[path] = name;
code += "function " + name + "(s){return '"+path+"'+s}";
}
});
(,function(packageName,basicsNumber){
if(basicsNumber > 1){
var name = (++);
[packageName] = name;
code += "var " + name + "='" + packageName + "';";
}
});
code += "return{";
(packages,function(packageName,config){
var basics = ;
var attrs = ;
var files = ;
var readPath = function(fileAddress){
var url = (fileAddress);
= "";
return ();
};
var filePath = function(file){
var url = (file);
var path = readPath(file);
var text = "";
if([path] > 1){
text = [path] + '(' + formatUrl() + ')';
}else{
text = formatUrl(file);
}
return text;
};
var basicPath = function(packageName){
var text = "";
if([packageName] > 1){
text = [packageName];
}else{
text = '"'+escape(packageName)+'"';
}
return text;
};
var filesPath = function(files){
if( === 1){
return filePath(files[0]);
}
var fileTextArray = [];
(files,function(i,path){
(filePath(path))
});
return "[" + (",") + "]";
};
var basicsPath = function(basics){
if( === 1){
return basicPath(basics[0]);
}
var basicsTextArray = [];
(basics,function(i,packageName){
(basicPath(packageName))
});
return "[" + (",") + "]";
};
code += '"'+packageName+'":';
if(isEmpty(basics) && isEmpty(attrs)){
if( > 0){
code += filesPath(files);
}else{
code += "null"
}
}else{
var args = [filesPath(files),basicsPath(basics)];
if(!isEmpty(attrs)){
var attrsCode = [];
(attrs,function(name,data){
if(isString(data) || isFunction(data)){
data = (data + "").trim();
}
if(isObject(data)){
if( === true){
(name + ":"+ );
}else{
(name + ":{parallel:false,files:"+ +"}");
}
}else if(isString(data) && !isEmpty(data)){
(name + ":"+ data)
}
});
if(!isEmpty(attrsCode)){
attrsCode = (",")
}
("{"+ attrsCode + "}");
}
code += "A(" +(",")+")";
}
code += ","
});
if(code[ - 1] === ","){
code = (0, - 1)
}
return code + "}});";
},
/*
* format package
*/
formatPackage:function(name,data){
var config = {
basics:[],
files:[],
attr: || null,
packageName:name,
version: || "",
documentation: || "",
description: || ""
};
if(isString(data) && !isEmpty(data)){
(data);
}
if(isArray(data)){
(data,function(i,fileAddress){
!isEmpty(fileAddress) && (fileAddress);
});
}
if(isString() && !isEmpty()){
();
}
if(isArray()){
(,function(i,packageName){
!isEmpty(packageName) && (packageName);
});
}
if(isString() && !isEmpty()){
();
}
if(isArray()){
(,function(i,fileAddress){
!isEmpty(fileAddress) && (fileAddress);
});
}
if(isObject()){
for(var name in ){
if(isFunction([name])){
[name] = {parallel:true,files:[name] + ""}
}
}
}
return config;
},
/*
* format packages
*/
formatPackages:function(){
var that = this;
(packages,function(name,data){
packages[name] = (name,data);
});
return packages;
},
/*
* add package row
*/
addPackageRow:function(name,data,type,index){
this._packagesGrid[type || "appendRow"]({
value:data,
cells:{
packageName:name,
version: || "",
basics:(" "),
documentation: || "",
description:
},
content:("grid_rowContent").render(data)
},index);
},
/*
* edit package
*/
editPackage:function(defaultValue,callback){
= false;
= false;
("",function(error,stl,exports){
if(!error){
exports(defaultValue,callback);
}
})
}
},
main:function(){
();
();
();
}
});
var mainInstance = new mainModule();
/**
* actions
*/
({
addPackage:{
icon:"add",
text:"添加包",
hotKey:"Ctrl+N",
main:function(){
(null,function(values,window){
if( in packages){
return ();
}
var packageData = packages[] = (,values);
(, packageData, "insertRow", 0);
mainInstance._packagesGrid.selectRow(0);
();
});
}
},
editPackage:{
icon:"edit",
text:"编辑选中包",
main:function(){
var selectedRow = mainInstance._packagesGrid.selectedRow(true);
selectedRow && (({},,3),function(values,window){
(,values);
= values["basics"].join(' ');
= values["version"] || "";
= values["documentation"] || "";
= values["description"];
= ("grid_rowContent").render(values);
mainInstance._packagesGrid.refresh();
();
});
}
},
deletePackage:{
icon:"delete",
text:"删除包",
hotKey:"delete",
main:function(){
var rows = mainInstance._packagesGrid.selectedRows(true);
var names = [];
var indexes = [];
if(!isEmpty(rows)){
(function(){
(rows,function(i,row){
(mainInstance._packagesGrid.indexOf(row));
delete packages[names[i] = ];
},true);
mainInstance._packagesGrid.removeRow(indexes);
});
}
}
},
reload:{
icon:"reload",
text:"重新载入",
main:function(){
mainInstance._packagesGrid.clearRows();
mainInstance._packagesLoaded = false;
(function(packages){
(packages,function(name,data){
(name,data);
});
});
}
},
save:{
icon:"save",
text:"保存配置",
main:(function(){
var code = ();
try{
new Function(code);
}catch(e){
return ("MessageBox").error("生成的js代码验证不通过,请检查是配置中否有特殊字符.");
}
if(typeof JSON === "undefined"){
return ("Notify").error("浏览器版本过低");
}
if(skipPassword){
(lastPassword,code)
}else{
("MessageBox").prompt("请输入密码:",null,"密码验证",function(password){
(lastPassword = password,code)
});
}
},{
packages:["","",""]
})
},
showExample:{
text:"使用例子",
main:function(){
var rowIndex = mainInstance._packagesGrid.selectedRow();
if(rowIndex !== -1){
(
mainInstance._packagesGrid.cell(rowIndex,0),
,
)
}
}
},
buildPackagesText:{
icon:"build",
text:"",
main:function(){
("",function(){
if(typeof JSON === "object"){
return (packages)
}
return "";
}())
}
},
buildIndexText:{
icon:"build",
text:"",
main:function(){
("",())
}
}
});
})
一键复制
编辑
Web IDE
原始数据
按行查看
历史