/en/,

时间:2025-03-06 17:40:55
Std Source Repository

//-----当前仓库版本号

= "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);

})();

=packageName?>=version?>=basics?>=description?>

包名称版本依赖包文档地址包描述

  • 包名称
  • 版本
  • 依赖包
  • 文档地址
  • 描述

文件列表:

#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

原始数据

按行查看

历史