javascript Object.extend的用法

Object.extend =  function(destination, source) {
for ( var property  in source) {
    destination[property] = source[property];
}
return destination;
}
Prototype 对Object类进行的扩展主要通过一个静态函数 Object.extend(destination, source)实现了 JavaScript中的继承。 从语义的角度, Object.extend(destination, source)方法有些不和逻辑, 因为它事实上仅仅实现了从源对象到目标对象的全息拷贝。不过你也可以这样认为:由于目标对象拥有了所有源对象所拥有的特性, 所以看上去就像目标对象继承了源对象(并加以扩展)一样。另外, Prototype对Object扩展了几个比较有用的静态方法, 所有其他的类可以通过调用这些静态方法获取支持。
JScript code
Object.extend =  function(destination, source) {  //  一个静态方法表示继承, 目标对象将拥有源对象的所有属性和方法
for ( var property  in source) {
    destination[property] = source[property];    //  利用动态语言的特性, 通过赋值动态添加属性与方法
}
return destination;    //  返回扩展后的对象
}

Object.extend(Object, { 
inspect:  function(object) {    //  一个静态方法, 传入一个对象, 返回对象的字符串表示
     try {
       if (object == undefined)  return 'undefined';  //  处理undefined情况
       if (object ==  nullreturn 'null';      //  处理null情况
       //  如果对象定义了inspect方法, 则调用该方法返回, 否则返回对象的toString()值
       return object.inspect ? object.inspect() : object.toString(); 
    }  catch (e) {
       if (e  instanceof RangeError)  return '...';  //  处理异常情况
       throw e;
    }
},
keys:  function(object) {      //  一个静态方法, 传入一个对象, 返回该对象中所有的属性, 构成数组返回
     var keys = [];
     for ( var property  in object)
      keys.push(property);      //  将每个属性压入到一个数组中
     return keys;
},
values:  function(object) {    //  一个静态方法, 传入一个对象, 返回该对象中所有属性所对应的值, 构成数组返回
     var values = [];
     for ( var property  in object) values.push(object[property]);  //  将每个属性的值压入到一个数组中
     return values;
},
clone:  function(object) {     //  一个静态方法, 传入一个对象, 克隆一个新对象并返回
     return  Object.extend({}, object);
}
});

/将这些方法添加到Set类的原型对象中
extend(Set.prototy,{
	toString:function(){
		var s="{",
		i=0;
		this.foreach(function(v){s+=((i++>0)?",":")+v});
		return s+"}";
	},
	toLocalString:function(){
		var s="{",i=0;
		this.foreach(function(v){
			if(i++>0)s+=",";
			if(v==null)s+=v;
			else s+=v.toLocalString();
		});
		return s+"}";
	},
	toArray:function(){
		var a=[];
		this.foreach(function(v){a.push(v);});
		return a;
	}
});
//对于要从JSON转换为字符串的集合都被当做数组来对待
Set.prototype.toJSON=Set.prototype.toArray;


你可能感兴趣的:(javascript Object.extend的用法)