js32---CommonUtil.js

简介:
// BH 命名空间  namespace
var BH = {} ;

BH.Interface = function(name,methods){  //Interface是类、方法的名字,以后用BH.Interface表示名字。new BH.Interface('CarInterface' ,['start','run']);当类用
    //判断接口的参数个数
    if(arguments.length != 2){
        throw new Error('this instance interface constructor arguments must be 2 length!');
    }
    this.name = name ; 
    this.methods = [] ; //定义一个内置的空数组对象 等待接受methods里的元素(方法名字)
    for(var i = 0,len = methods.length ; i <len ; i++){
         if( typeof methods[i] !== 'string'){
                 throw new Error('the Interface method name is error!');
         }
         this.methods.push(methods[i]);
    }
}


// 三:检验接口里的方法
BH.Interface.ensureImplements = function(object){
    // 如果检测方法接受的参数小于2个 参数传递失败!
    if(arguments.length < 2 ){
        throw new Error('Interface.ensureImplements method constructor arguments must be  >= 2!');
    }
    
    // 获得接口实例对象 
    for(var i = 1 , len = arguments.length; i<len; i++ ){
        var instanceInterface = arguments[i];
        // 判断参数是否是接口类的类型
        if(instanceInterface.constructor !== BH.Interface){
            throw new Error('the arguments constructor not be Interface Class');
        }
        // 循环接口实例对象里面的每一个方法
        for(var j = 0 ; j < instanceInterface.methods.length; j++){
            // 用一个临时变量 接受每一个方法的名字(注意是字符串)
            var methodName = instanceInterface.methods[j];
            // object[key] 就是方法
            if( !object[methodName] || typeof object[methodName] !== 'function' ){
                throw new Error("the method name '" + methodName + "' is not found !");
            }
        }
    }
};

BH.extend=function(sub ,sup){
     var F = new Function();    // 1 创建一个空函数    目的:空函数进行中转
     F.prototype = sup.prototype; // 2 实现空函数的原型对象和超类的原型对象转换
     sub.prototype = new F();     // 3 原型继承 
     sub.prototype.constructor = sub ; // 4还原子类的构造器
     //保存一下父类的原型对象: 一方面方便解耦  另一方面方便获得父类的原型对象
     sub.superClass = sup.prototype; //自定义一个子类的静态属性 接受父类的原型对象
     //判断父类的原型对象的构造器 (加保险)
     if(sup.prototype.constructor == Object.prototype.constructor){
         sup.prototype.constructor = sup ; //手动欢迎父类原型对象的构造器
     }
};


/**
 * 单体模式
 * 实现一个跨浏览器的事件处理程序。一个冒泡事件一个捕获事件。
 */
BH.EventUtil = {
    addHandler:function(element , type , handler){
        if(element.addEventListener){        //FF
            element.addEventListener(type,handler,false);//false表示冒泡
        } else if(element.attachEvent){        //IE
            element.attachEvent('on'+type , handler);
        }
    } , 
    removeHandler:function(element , type , handler){
        if(element.removeEventListener){        //FF
            element.removeEventListener(type,handler,false);
        } else if(element.detachEvent){        //IE
            element.detachEvent('on'+type , handler);
        }        
    }
};


Array.prototype.each = function(fn){
    try{
        this.i || (this.i=0);  //var i = 0 ;
        if(this.length >0 && fn.constructor == Function){
            while(this.i < this.length){    //while循环的范围 
                var e = this[this.i];
                if(e && e.constructor == Array){
                    e.each(fn);
                } else {
                    //fn.apply(e,[e]);
                    fn.call(e,e);
                }
                this.i++ ;
            }
            this.i = null ; // 释放内存 垃圾回收机制回收变量
        }
    } catch(ex){
        // do something 
    }
    return this ;
}
复制代码

 



本文转自农夫山泉别墅博客园博客,原文链接:http://www.cnblogs.com/yaowen/p/6886881.html,如需转载请自行联系原作者
相关文章
|
7月前
|
JavaScript
什么是js?js的特点是什么?
什么是js?js的特点是什么?
|
4月前
|
自然语言处理 JavaScript
js之this
js之this
32 1
|
7月前
|
XML JavaScript 前端开发
js的一些总结
js的一些总结
44 1
|
7月前
|
JavaScript 前端开发
JS实现日历表
JS实现日历表
36 0
|
移动开发 JavaScript 前端开发
什么是js? js的特点是什么?
什么是js? js的特点是什么?
86 0
|
JavaScript
JS数学方法
JS数学方法
|
JavaScript
js小技巧(2)
js小技巧(2)
|
JavaScript 前端开发 算法
JS之BigNumber.js 讲解
JS之BigNumber.js 讲解
1297 0
JS之BigNumber.js 讲解
|
JSON API 数据格式
一起来学 next.js - getServerSideProps 篇
getServerSideProps 是 next.js 中的一项特色功能,可以让我们在给页面设置一些初始的 props 参数。
|
JavaScript 索引
js中for in和for of详细讲解
js中for in和for of详细讲解
js中for in和for of详细讲解
下一篇
DataWorks