JavaScript 中如何快速地复制对象(深拷贝、浅拷贝)

一、对象、数组通用

遍历赋值(深拷贝)

// 定义遍历赋值的函数
let cloneObj = function (obj) {
  let newObj = obj instanceof Array ? [] : {}

  for (let key in obj) {
    let val = obj[key]

    newObj[key] = typeof val === 'object' ? cloneObj(val) : val
  }
  return newObj
}
// 测试
const list = {
  id: 'a',
  title: 'A',
  authors: ['y', 'h'],
}
let list2 = cloneObj(list)
list2.authors[0] = 'a'
console.log(list)
console.log(list2)

在这里插入图片描述

借助 JSON (深拷贝)

先将对象变为字符串,然后再变为 json 对象。

  • undefined 和 function 类型的属性会被忽略,而 Date 类型的属性则会被转换为字符串
let newObj = JSON.parse(JSON.stringify(obj))
// 测试
const list = {
  id: 'a',
  title: 'A',
  authors: ['y', 'h'],
}

let list2 = JSON.parse(JSON.stringify(list))
list2.authors[0] = 'a'
console.log(list)
console.log(list2)

// 结果与上面一致

二、特定用法

对象拷贝-扩展运算符(浅拷贝)

只能实现表层的拷贝,深层的不行

let newObj = { ...obj }
// 测试
const list = {
  id: 'a',
  title: 'A',
  authors: ['y', 'h'],
}

let list2 = { ...list }
list2.authors[0] = 'a'
list2.id = 'c'
console.log(list)
console.log(list2)

在这里插入图片描述

数组拷贝-concat 方法(浅拷贝)

借助数组的方法 concat,只能实现表层拷贝

let newArr = [].concat(arr)
// 测试
const list = [
  1,
  2,
  3,
  {
    id: 'a',
    title: 'A',
  },
]

let list2 = [].concat(list)

list2[0] = 'a'
list2[3].id = 'c'
console.log(list)
console.log(list2)

在这里插入图片描述

数组拷贝-扩展运算符(浅拷贝)

与对象的扩展运算符用法一致

let newArr = [...arr]
// 测试
const list = [
  1,
  2,
  3,
  {
    id: 'a',
    title: 'A',
  },
]

let list2 = [].concat(list)

list2[0] = 'a'
list2[3].id = 'c'
console.log(list)
console.log(list2)

// 结果与上面一致

参考:Javascript如何复制对象-js教程-PHP中文网

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值