JavaScript 复制对象

本文介绍了一种在JavaScript中实现对象深拷贝的方法。通过使用`Object.create`来复制原型,并利用`Object.getOwnPropertyNames`与`Object.defineProperty`来逐个复制源对象的所有自有属性。

首先,为了创建一个对象完全相同的拷贝,需要确保两件事情: 

  1. 拷贝必须具有与原对象相同的原型

  2. 拷贝必须具有与原对象相同的属性和特性。

 

function copyObject (orig) {
    //1. 具有相同的原型
   var copy  = Object.create(Object.getPrototypeOf(orig));  

    // 2. 具有相同的属性和特性
    copyOwnPropertiesFrom(copy, orig);     

    return copy;  
}

//属性复制

function copyOwnPropertiesFrom(target, source) {
   Object.getOwnPropertyNames(source)   //(1)
    . forEach(function (propKey) {   //(2)
             var desc = Object.getOwnPropertyDescriptor(source, propKey); //(3)
             Object.defineProperty(target, propKey, desc); //(4)
    });
    return target;
}

  步骤如下:

(1) 获得 source 所有自由属性的数组。

(2) 遍历这些键。

(3) 获取属性描述符

(4) 使用属性描述符创建 target 的自有属性

 

转载于:https://www.cnblogs.com/jiaxinjie/p/8027855.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值