Hutia 的 JS 代码集_javascript技巧

main.basic.js

复制代码 代码如下:

/**************************************************
 *        The Basic Lib for HUTIA frame work
 * Author: Hutia
 * E-Mail: Hutia2@gmail.com
 * Create: 2006-08-21
 * Last Modify: 2006-08-26
 * Version: 1.02
 * Copyright Declare: Everybody can use for freely but can not be used in commerce.
 *
 * Please keep this information while quote.
**/

//******** BEFORE ALL **************
var currentLibName="main.basic";

try{ // catch all the exceptions during loading

//================= Declare CONSTANT Section === Start ===========
var vbOK=0;    var vbOKCancel=1;    var vbAbortRetryIgnor=2;    var vbYesNoCancel=3;
var vbYesNo=4;    var vbRetryCacel=5;    var vbStop=16;    var vbQuest=32;    var vbAlert=48;
var vbInfo=64;    var vbReturnOK=1;    var vbReturnCacel=2;    var vbReturnAbort=3;
var vbReturnRetry=4;    var vbReturnIgnor=5;    var vbReturnYes=6;    var vbReturnNo=7;
var vbCrLf="\r\n";

//----------------- Declare CONSTANT Section - End ---------------
/////////////////////////////////////////////////////////////////////////
//================= Declare Global Variable Section === Start ===========
var SITE_ROOT="E:\\hutia\\program\\Developing\\GJS_v3".replace(/\\/g,"\/").replace(/([^\/])$/,"$1\/");

//----------------- Declare Global Variable Section - End ---------------
/////////////////////////////////////////////////////////////////////////
//================= Declare Global Function Section === Start ===========

// Alia Name for AsynLoader.depend
$depend=function(str,currentLibName,defer){
    AsynLoader.depend(str,currentLibName,defer);
}

// Alia Name for AsynLoader.include
$include=function(str){
    AsynLoader.include(str);
}

function say(str){
    alert(str);
}

function uid(){
    return("u"+(new Date()).getTime().toString(35)+parseInt(Math.random()*999999).toString(35));
}

//----------------- Declare Global Function Section - End ---------------
/////////////////////////////////////////////////////////////////////////
//================= Declare Global Object Section === Start ===========
// The asynchronous loader
var AsynLoader= new function(){
    // delare private variable
    var alias, currentPath, dependences, dependent, libs, paths;
}

AsynLoader.alertLoadResult=function(){
    var str="";
    for(var i in libs){if(libs[i]=="loaded"){str+="Load \""+i+"\" Successfully.\r\n";}else{str+=libs[i]+"\r\n";}}
    say(str);
}

AsynLoader.alias=function(aliasName,strPath,singleInstance){
    strPath=this.getPath(strPath);
    if(!strPath||typeof(aliasName)!="string"||aliasName=="")return;
    alias[aliasName]=strPath;
    alias[aliasName][2]=Boolean(singleInstance);
}

AsynLoader.depend=function(strLibName,strSrcLibName,defer){
    if(typeof(strLibName)!="string"||strLibName=="")throw("Invalid Lib Name.");
    if(libs[strLibName]!="loaded"){
        if(defer&&alias[strLibName]){
            AsynLoader.include(strLibName);
        }else throw("Dependence validation failure.\r\n"+libs[strLibName]);
    }
    if(typeof(strSrcLibName)=="string"&&strSrcLibName!=""){
        temp=strSrcLibName+" => "+strLibName;
        dependences.push(temp);
    }
}

AsynLoader.getDependBy=function(str){
    var re=new Array();
    for(var i=0;i<dependences.length;i++)if(dependences[i].split(" => ")[1]==str)re.push(dependences[i].split(" => ")[0]);
    return(re.join(";"));
}

AsynLoader.getDependOn=function(str){
    var re=new Array();
    for(var i=0;i<dependences.length;i++)if(dependences[i].split(" => ")[0]==str)re.push(dependences[i].split(" => ")[1]);
    return(re.join(";"));
}

AsynLoader.getLibs=function(){
    var re=new Array(), hash=new Array();
    for(var i in libs)if(!hash[i]){hash[i]=true;re.push(i);}
    re.sort();
    return(re.join(";"));
}

AsynLoader.getPath=function(strPath){
    var ext, i, re, strPath;
    if(typeof(strPath)!="string"||strPath=="")return(false);
    ext="js";
    if(strPath.indexOf(":")==-1)if(this.pathType=="absolute"){strPath=SITE_ROOT+currentPath+strPath;}else{strPath=currentPath+strPath;}
    i=strPath.lastIndexOf(".");
    if(i!=-1&&i<strPath.length-2){
        ext=strPath.substring(i+1).toLowerCase();
    }else{
        strPath=strPath+"."+ext;
    }
    return([strPath,ext]);
}

AsynLoader.include=function(strPath,className){
    var ext, i, singleInstance, strPath;
    if(alias[strPath]){
        strPath=alias[strPath];
    }else{
        strPath=this.getPath(strPath);
    }
    if(!strPath)return(false);
    ext=strPath[1];
    singleInstance=Boolean(strPath[2])||className=="singleInstance"||paths[strPath]=="singleInstance";
    strPath=strPath[0];
    if(singleInstance&&paths[strPath])return;
    paths[strPath]=singleInstance?"singleInstance":true;
    switch(ext){
        case "js":
            document.write("<scr"+"ipt type=\"text\/javascript\" src=\""+strPath+"\" ><\/scr"+"ipt>");
        break;
        case "vbs":
            document.write("<scr"+"ipt type=\"text\/vbscript\" src=\""+strPath+"\"><\/scr"+"ipt>");
        break;
        case "css":
            document.write("<link rel=\"stylesheet\" type=\"text\/css\" href=\""+strPath+"\" \/>");
        break;
        case "jpg": case "gif": case "bmp": case "jpeg": case "png":
            document.write("<img alt=\"\" "+(className?" class=\""+className+"\" ":"")+" src=\""+strPath+"\" \/>");
        break;
        default:
            document.write("<iframe frameBorder=\"0\" "+(className?" class=\""+className+"\" ":"")+" src=\""+strPath+"\"><\/iframe>");
        break;
    }
}

AsynLoader.init=function(){
    alias=new Array();
    currentPath="";
    dependences=new Array();
    dependent=new Array();
    libs=new Array();
    paths=new Array();

    this.pathType="absolute";
}

AsynLoader.libs=function(blnNotLoaded){
    var re=new Array();
    for(var i in libs)if((libs[i]=="loaded")^blnNotLoaded)re.push(i);
    return(re);
}

AsynLoader.loadFailure=function(strLibName,e){
    if(e=="exit")return;
    libs[strLibName]="Loading "+strLibName+" model Failed:\r\n";
    for(var i in e)libs[strLibName]+="  "+i+":"+e[i]+"\r\n";
}

AsynLoader.loadSuccess=function(strLibName){
    libs[strLibName]="loaded";
}

AsynLoader.setPath=function(strPath){
    if(typeof(strPath)!="string")return;
    currentPath=strPath.replace(/\\/g,"\/").replace(/([^\/])$/,"$1\/");
}

AsynLoader.singleInstance=function(strPath){
    if(alias[strPath]){
        strPath=alias[strPath];
    }else{
        strPath=this.getPath(strPath);
    }
    if(!strPath)return(false);
    strPath=strPath[0];
    if(paths[strPath]){
        throw("exit");
    }else{
        paths[strPath]=true;
    }
}

AsynLoader.init();

//----------------- Declare Global Object Section - End ---------------
/////////////////////////////////////////////////////////////////////////
//================= Initialization Section === Start ===========
AsynLoader.pathType="relative";
AsynLoader.include("js/main.alias.js");

//----------------- Initialization Section - End ---------------
//***************** AFTER ALL ***********************

AsynLoader.loadSuccess(currentLibName);

}catch(e){ AsynLoader.loadFailure(currentLibName); }

////////////////////////////////////////////////////////////////
///////////////////       File End    //////////////////////////
////////////////////////////////////////////////////////////////

时间: 2024-10-29 10:18:49

Hutia 的 JS 代码集_javascript技巧的相关文章

移动端横屏的JS代码(beta)_javascript技巧

废话不多说了,直接给大家贴代码了 具体代码如下所示: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"

如何编写高质量JS代码(续)_javascript技巧

继续上一篇文章<如何编写高质量JS代码>今次整理一下javascript函数知识点. 2.使用函数 函数给程序员提供了主要的抽象功能,又提供实现机制.函数可以独立实现其他语言中的多个不同的特性,例如,过程.方法.构造函数,甚至类或模块. 2.1 理解函数调用.方法调用以及构造函数调用之间的不同 针对面向对象编程,函数.方法和类的构造函数是三种不同的概念. 使用模式: 1,函数调用 复制代码 代码如下: function hello(username){     return "hel

同步文本框内容JS代码实现_javascript技巧

本文实例为大家分享了同步文本框内容JS代码,供大家参考,具体内容如下 图例1  <html> <body> <script language="JavaScript" type="text/javascript"> function addEvent(eventHandler) { var tags = document.getElementsByTagName('input'); for(var i=0;i<tags.le

更靠谱的H5横竖屏检测方法(js代码)_javascript技巧

前不久,做了一个H5项目,需要在横竖屏变化时,做一些处理.毫无疑问,需要使用orientationchange来监听横竖屏的变化. 方案一: // 监听 orientation changes window.addEventListener("orientationchange", function(event) { // 根据event.orientation|screen.orientation.angle等于0|180.90|-90度来判断横竖屏 }, false); 代码添加上

前端设计师们最常用的JS代码汇总_javascript技巧

逛社区时看到的文章,我修改调整了内容,如果大家觉得也有帮助 可以收藏下~ HTML5 DOM 选择器 // querySelector() 返回匹配到的第一个元素 var item = document.querySelector('.item'); console.log(item); // querySelectorAll() 返回匹配到的所有元素,是一个nodeList集合 var items = document.querySelectorAll('.item'); console.lo

TBCompressor js代码压缩_javascript技巧

TBCompressor 公司原先的JS和CSS文件都是用在线压缩程序压缩的,看似方便,但很容易出错,可能是压缩程序把CSS里面的一些Hack语句给混淆了,于是我决定用大名鼎鼎的YUI compressor. 但YUI compressor也有一个缺点,那就是操作不人性化,要用输入命令行的方式进行操作,在实际应用中也有点不方便.今天发现了淘宝人开发的一个软件--TBCompressor,这个软件是在YUI compressor的基础上改进的,使用十分简单,详情请看lifesinger的<TBCo

EditPlus注册码生成器(js代码实现)_javascript技巧

今天同事惊奇的告诉我,说找到个在线的EditPlus注册码生成器,我赶紧去看了看,还真是,在这里. exe的注册机病毒太多,纯js的在线注册机可就放心了. 作者是从别人的注册机反汇编然后找出算法的,更令我惊奇的是,这作者Demon竟然是搞法律的,才刚拿到法律职业资格证书,佩服. 主要的一个js函数是这样的: 复制代码 代码如下: function generate_editplus_regcode(username){ var list = [0,49345,49537,320,49921,96

兼容ie、firefox的图片自动缩放的css跟js代码分享_javascript技巧

这个功能主要是解决内容页中的图片过大撑出,导致页面比较难看,就需要这样的代码,需要的朋友可以参考下 需求:图片width<=600px,height<=800. 1.利用max-width,max-height使图片等比例自动缩放代码: 复制代码 代码如下: img{max-width: 600px;max-height: 800px;} 由于ie6不支持css max-width,max-height,所以在ie6中需要利用javascript脚本来控制大小. 2.用javascript脚本

向左滚动文字 js代码效果_javascript技巧

复制代码 代码如下: <html><head><title>滚动文字效果</title><style type="text/css">#infozone{font-size:12px;color:#aa6;overflow:hidden;width:100px;height:20px;}#infozone div{height:20px;line-height:20px;white-space:nowrap;overflow: