两种方式实现浅拷贝 for in实现和Object.assign({}, 对象1, 对象2);

浅拷贝只拷贝对象的一层,如果对象的属性还是对象,那么user3和user4这两个对象对应的值都会发生改变
复制代码
  // 拷贝分为浅拷贝和深拷贝。
        
        // 浅拷贝的实现 通过for in实现
        var user1 = {
            name: "小明",
            age: 30,
            height: 1.9
        };
        var user2 = {};
        for (var i in user1) {
            user2[i] = user1[i]; //user[i]输出的是每一个值,将user1的每一个值赋予给user2对象
        }
        console.log(user2) //{name: "小明", age: 30, height: 1.9}



        // 浅拷贝 通过Object.assign({}, 对象1, 对象2);
        // 这一种浅拷贝方式类似于jquery的$.extend({}, 对象1, 对象2)
        var obj1 = {
            name: "小明",
            age: 13
        };
        var obj2 = {
            name: "大王",
            tel: 18456888
        };
        var obj = Object.assign({}, obj1, obj2);
        console.log(obj) //{name: "大王", age: 13, tel: 18456888}
        // 我们发现这一种方式,相同的key值后一个会覆盖前一个的key值,


        //浅拷贝只拷贝对象的一层,如果对象的属性还是对象,那么user3和user4这两个对象对应的值都会发生改变
        var user3={name:"小明",age:18, deMent:{bumen:"市场部",no:"001"}}
        var user4={};
        for(var i in user3){
            user4[i]=user3[i];
        }
        user4.age=80;   //这个值 不会互相影响改变
        user4.deMent.bumen="策划部"; //这个值 会互相影响改变

        console.log(user3); //输出  {name: "小明", age: 18,deMent:{bumen: "策划部", no: "001"} }

        console.log(user4); //{name: "小明", age: 80,deMent: {bumen: "策划部", no: "001"}}
复制代码

 

posted @   南风晚来晚相识  阅读(815)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
点击右上角即可分享
微信分享提示