javascript Object.extend的用法

来源:互联网 发布:windows下打包tar.gz 编辑:程序博客网 时间:2024/05/05 02:07

======================================================
注:本文源代码点此下载
======================================================

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 == null) return '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);

}

});


======================================================
在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定 这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/
原创粉丝点击