js技巧,对象的深浅拷贝,栈和堆?

基本数据类型一般都是存在栈里
引用数据类型是存在堆里面的

let obj = {
name:"张麻子"
}
let obj1 = Object.assign({},obj,{age:20});
let obj1 ={...obj} //扩展运算符用法
obj1.name = "刘傻子"
console.log(obj)
//assign 合并对象的意思,可以合并多个对象,跟扩展运算符差不多
//assign(最少接受两个参数)

递归函数

let num = 10;
for( let i =0;i<num;i++){
    console.log(i)
}

//简单的说,函数自己掉自己 就是是递归函数

function fn () {  //注意我们在使用递归的时候,一定不能写成死循环(我们一般用return打断循环)
//fn() 不能在这里调用
console.log('我被执行了')
}

fn()//fn()在哪里都能调用

怎么使用 递归实现一个深拷贝呢

  let obj = {
     name: '张三',
     msg:{
       ext: '今年18了'
     }
   }
function copy(obj) { // obj 传入的对象就是你要拷贝的对象
    let newObj = null; // 声明一个对象来存储拷贝之后的内容
    // 判断数据类型是否是复杂的数据类型,如果是则调用自己,如果不是则直接赋值即可!
    // 由于null不可以循环但是他的类型又是object,所以这个需要对null进行判断
    // typeof 判断数据类型 object , array ,null 返回的值都是 'object'
    // debugger
    if (typeof(obj) == 'object' && obj !== null){
        // 声明一个变量用以存储拷贝出来的值,根据参数的具体数据类型声明不同的类型来存储
        newObj = obj instanceof Array? [] : {};
        // 循环obj的每一项,如果里面还有复杂的数据类型的话,则直接利用递归函数再次调用。
        for(let i in obj){ // i 这里的 i 有可能是 属性名 或者 索引
            newObj[i] = copy(obj[i])
        }
    } else {
        newObj = obj
    }
    return newObj; // 函数没有返回的值的话,则为undefined
}

let obj1 = copy(obj);
obj1.msg.ext = '我今年20了';
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容