Vue中一行代码实现深拷贝

在Vue开发中,确保数据副本不会影响原始双向绑定数据是至关重要的。直接浅拷贝可能导致副本和原始数据同步变化,引起未预期的后果。为解决这个问题,可以使用JSON.parse(JSON.stringify())方法或递归方式实现深拷贝。递归深拷贝函数能处理复杂对象和循环引用,避免数据篡改风险。
摘要由CSDN通过智能技术生成

应用场景

  • 在vue开发过程中,我们可能会遇到要对双向绑定的数据拷贝一个副本来供我们使用,如果直接浅拷贝会造成一定的风险。比如: 在拷贝后我们要更改副本, 这是由于双向绑定的原因, 之前的数据也会改变, 会出现问题。 这是新手容易忽略的地方。

解决方案

  • 实现深拷贝
  1. JSON
const obj1 = JSON.parse(JSON.stringify(obj2))
  1. 递归
// 判断是不是数组和对象
function isObject (o) {
  return Object.prototype.toString.call(o) === '[object Array]' || Object.prototype.toString.call(o) === '[object Object]'
}
// 实现深拷贝函数
// 利用Map数据结构来解决循环引用造成死循环的问题
function deepclone (o, hash = new Map()) {
  //判断类型,只适用于array和object
  if (!isObject(o)) {
    return o
  }
  // 判断循环引用
  if (hash.has(o)) {
    return hash.get(o)
  }
  const obj = Array.isArray(o) ? [] : {}
  hash.set(o, obj)
  for (const k in o) {
    if (isObject(o[k])) {
      obj[k] = deepclone(o[k], hash)
    } else {
      obj[k] = o[k]
    }
  }
  return obj
}
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值