分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 软件开发

js如何复制一个对象?

发布时间:2023-09-06 01:55责任编辑:蔡小小关键词:js

方法一:

把原来对象的属性遍历一遍,赋给一个新的对象。

//深复制对象方法 ???var cloneObj = function (obj) { ?????var newObj = {}; ?????if (obj instanceof Array) { ?????????newObj = []; ?????} ?????for (var key in obj) { ?????????var val = obj[key]; ?????????//newObj[key] = typeof val === ‘object‘ ? arguments.callee(val) : val; //arguments.callee 在哪一个函数中运行,它就代表哪个函数, 一般用在匿名函数中。 ?????????newObj[key] = typeof val === ‘object‘ ? cloneObj(val): val; ?????} ?????return newObj; ?}; ?//测试 ???var obj = {a:function(){console.log(this.b.c)},b:{c:1}},//设置一个对象 ?newObj = cloneObj(obj);//复制对象 ?newObj.b.c=2;//给新对象赋新值 ?obj.a();//1,不受影响 ?newObj.a();//2 ?

方法二:

将对象序列化再解析回来,对象中如果有函数function则不能正确复制

var obj = {a:1,b:2} ?var newObj = JSON.parse(JSON.stringify(obj)); ?newObj.a=3; ?console.log(obj); ?console.log(newObj); ?

方法三:

针对数组对象的方法,用数组方法concat一个空数组

var a=[1,2,3]; ?var b=a; ?var c=[].concat(a); ?a.push(4); ?console.log(b); ?console.log(c); 

转自:https://blog.csdn.net/liyujia6636/article/details/52198128

js如何复制一个对象?

原文地址:https://www.cnblogs.com/hjbky/p/9068258.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved