码迷,mamicode.com
首页 > Web开发 > 详细

js实现深拷贝

时间:2018-10-29 16:09:08      阅读:180      评论:0      收藏:0      [点我收藏+]

标签:prope   lse   实现   turn   log   数据类型   font   拷贝   指针   

  js的数据类型分为基本数据类型和引用数据类型。基本数据类型是直接赋值,引用数据类型分为浅拷贝和深拷贝。浅拷贝是复制对象的指针,深拷贝是复制对象所有属性再内存中独立存在。

  浅拷贝如下:

var obj = {a: ‘test‘, b: {c: 0}}
var obj1 = obj
var obj2 = shallowCopy(obj);
function shallowCopy(src) {
    var dst = {};
     for (var prop in src) {
         if (src.hasOwnProperty(prop)) {
             dst[prop] = src[prop];
          }
      }
     return dst;
}

var obj3 = Object.assign({}, obj)

obj.a = ‘arr‘
obj.b.c = 1

console.log(obj) // {a: ‘arr‘, b: {c: 1}}
console.log(obj1) // {a: ‘arr‘, b: {c: 1}}
console.log(obj2) // {a: ‘test‘, b: {c: 1}}
console.log(obj3) // {a: ‘test‘, b: {c: 1}}

  深拷贝实现如下:

function extend (source) {
  var target
  if (typeof source === ‘object‘) {
    target = Array.isArray(source) ? [] : {}
    for (var key in source) {
      if (source.hasOwnProperty(key)) {
        if (typeof source[key] !== ‘object‘) {
          target[key] = source[key]
        } else {
          target[key] = extend(source[key])
        }
      }
    }
  } else {
    target = source
  }
  return target
}

var obj1 = {a: {b: 0}}
var cpObj1 = extend(obj1)
obj1.a.b = 1
console.log(cpObj1) // {a: {b: 0}}

var obj2 = [[0]]
var cpObj2 = extend(obj2) 
obj2[0][0] = 1
console.log(cpObj2) // [[0]]

  

js实现深拷贝

标签:prope   lse   实现   turn   log   数据类型   font   拷贝   指针   

原文地址:https://www.cnblogs.com/zjp-zxy/p/9870658.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!