详谈JS拷贝

浅拷贝

递归

浅拷贝是创建一个对象,这个对象有着原始对象的一份精确拷贝。如果属性是基本数据类型,拷贝的就是基本数据类型的值,如果是引用数据类型,拷贝的是内存地址,所以如果其中一个对象改变了这个地址,就会影响另一个对象。(如下图)

   	 	let obj = {
            name: 'lyz',
            hobbies: ['study', ['TV', 'sing']]
        }
        function lightCopy(obj) {
            let newObj = obj.constructor()
            // let newObj = {}
            for(var key in obj) {
                if(obj.hasOwnProperty(key)) {
                    newObj[key] = obj[key]
                }
            }
            return newObj
        }
        let newObj = lightCopy(obj)
        newObj.name = 'my'
        newObj.hobbies[0] = 'computer'
        console.log(obj)
        console.log(newObj)

在这里插入图片描述

Object.assign

…(展开运算符)

Array.prototype.concat

Array.prototype.slice

深拷贝

递归

深拷贝是将对象从内存中完善的拷贝一份,从对内存中开辟一个新的区域存放新对象,对对象中的子对象进行递归,且修改新对象不会影响原来的对象。(如下图)

		let obj = {
            name: 'lyz',
            hobbies: ['study', ['TV', 'sing']],
            reg: /99/
        }
 		function deepCopy(obj) {
            let newObj = {}
            if(obj === null) return
            if(obj instanceof Date) return new Date(obj)
            if(obj instanceof RegExp) return new RegExp(obj)
            if(typeof(obj) !== 'object' ) return obj
            for(let key in obj) {
                if(obj.hasOwnProperty(key)) {
                    newObj[key] = deepCopy(obj[key])
                }
            }
            return newObj
        }
        let newObj = deepCopy(obj)
        newObj.name = 'my'
        newObj.hobbies[0] = 'computer'
        console.log(obj)
        console.log(newObj)

在这里插入图片描述

JSON.parse(JSON.stringify())

缺点:对正则、函数不能深拷贝

		let obj = {
            name: 'lyz',
            hobbies: ['study', ['TV', 'sing']],
            reg: /99/,
            get: function () {
                
            }
        }
  		let newO = JSON.parse(JSON.stringify(obj))
        console.log(newO)

在这里插入图片描述

cloneDeep

Jquery.extend()

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值