JavaScript复制变量三种方法实例详解


Posted in Javascript onJanuary 09, 2020

这篇文章主要介绍了JavaScript复制变量三种方法实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

直接将一个变量赋给另一个变量时,系统并不会创造一个新的变量,而是将原变量的地址赋给了新变量名。举个栗子:
复制代码
复制代码
let obj = {
a: 1,
b: 2,
};
let copy = obj;

obj.a = 5;
console.log(copy.a);
// Result
// a = 5; // 更改obj的值,copy变量的值也会改变
复制代码
复制代码
文章中提到了很多种办法,本文只选择了三种普遍的用法并分析了各自的优缺点,以及什么情况下使用哪种是最好的。

1. 原生方法解决
最简单的办法就是一个一个循环复制给新的变量。举栗:

复制代码
复制代码
function copy(mainObj) {
let objCopy = {}; // objCopy will store a copy of the mainObj
let key;

for (key in mainObj) {
objCopy[key] = mainObj[key]; // copies each property to the objCopy object
}
return objCopy;
}

const mainObj = {
a: 2,
b: 5,
c: {
x: 7,
y: 4,
},
}

console.log(copy(mainObj));
复制代码
复制代码
缺点:

1. objCopy 的Object.prototype 方法与mainObj 会不一样,通常情况下我们需要完全一样的副本时,这个办法并不适用。

2. 麻烦而且费时费事,代码无法重用。

3. 如果原来的变量中包含Object类型,复制时还是会把这个子变量的索引交给新的变量,并不是创建了新的副本。

2. 深度复制
利用JSON转换来复制变量。先将原先的变量转换为String然后再重新组装成JSON,这样会产生一个不一样的副本。

复制代码
复制代码
let obj = {
a: 1,
b: {
c: 2,
},
}

let newObj = JSON.parse(JSON.stringify(obj));

obj.b.c = 20;
console.log(obj); // { a: 1, b: { c: 20 } }
console.log(newObj); // { a: 1, b: { c: 2 } } (New Object Intact!)
复制代码
复制代码
缺点:

1. 变量很多的时候非常耗时耗内存。

3. 使用Object.assign()
使用举例:

复制代码
复制代码
// circular object
let obj = {
a: 'a',
b: {
c: 'c',
d: 'd',
},
}

obj.c = obj.b;
obj.e = obj.a;
obj.b.c = obj.c;
obj.b.d = obj.b;
obj.b.e = obj.b.c;

let newObj2 = Object.assign({}, obj);

console.log(newObj2);
复制代码
复制代码
可以把它封装成一个方法:

复制代码
// 封装成方法
// 返回一个新的变量副本
// get a copy of an object
function getNewObjectOf(src) {
return Object.assign({}, src);
}
复制代码
缺点:

1. 这个也是浅复制(仅复制顶层的属性,底层属性并不复制)。深层属性会同样返回索引,与原变量分享一个地址。(看下面栗子)

复制代码
复制代码
let obj = {
a: 1,
b: {
c: 2,
},
}
let newObj = Object.assign({}, obj);
console.log(newObj); // { a: 1, b: { c: 2} }

obj.a = 10;
console.log(obj); // { a: 10, b: { c: 2} }
console.log(newObj); // { a: 1, b: { c: 2} }

newObj.a = 20;
console.log(obj); // { a: 10, b: { c: 2} }
console.log(newObj); // { a: 20, b: { c: 2} }

newObj.b.c = 30;
console.log(obj); // { a: 10, b: { c: 30} }
console.log(newObj); // { a: 20, b: { c: 30} }

// 注意: 所有变量 的 *。b.c 都等于30; 原因看上面解释。
复制代码
复制代码

结论:
原文中还有很多其他的办法,但此文仅摘抄出最有用的几个。一般不会用到第一种办法,如需要复制的变量有很多层的话,需要用第二种办法来复制,如果变量仅仅包含一层(如json格式的配置信息变量),第三种是最高效的。

再次给出封装好的方法:

// 封装成方法// 返回一个新的变量副本
// get a copy of an object
function getNewObjectOf(src) {
 return Object.assign({}, src);
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
IE 下Enter提交表单存在重复提交问题的解决方法
May 04 Javascript
在JavaScript中使用timer示例
May 08 Javascript
jQuery响应鼠标事件并隐藏与显示input默认值
Aug 24 Javascript
node.js中的buffer.Buffer.byteLength方法使用说明
Dec 10 Javascript
JS、jQuery中select的用法详解
Apr 21 Javascript
使用CSS+JavaScript或纯js实现半透明遮罩效果的实例分享
May 09 Javascript
详解AngularJs ui-router 路由的简单介绍
Apr 26 Javascript
使用jQuery实现购物车结算功能
Aug 15 jQuery
jQuery使用jsonp实现百度搜索的示例代码
Jul 08 jQuery
javascript利用canvas实现鼠标拖拽功能
Jul 23 Javascript
解决vue prop传值default属性如何使用,为何不生效的问题
Sep 21 Javascript
vue组件冲突之引用另一个组件出现组件不显示的问题
Apr 13 Vue.js
js实现左右轮播图
Jan 09 #Javascript
Vue-axios-post数据后端接不到问题解决
Jan 09 #Javascript
一看就会的vuex实现登录验证(附案例)
Jan 09 #Javascript
Websocket 向指定用户发消息的方法
Jan 09 #Javascript
Vue快速实现通用表单验证的示例代码
Jan 09 #Javascript
JS实现商品橱窗特效
Jan 09 #Javascript
微信小程序实现页面浮动导航
Jan 08 #Javascript
You might like
php中批量删除Mysql中相同前缀的数据表的代码
2011/07/01 PHP
浅析php中json_encode()和json_decode()
2014/05/25 PHP
PHP不使用内置函数实现字符串转整型的方法示例
2017/07/03 PHP
用javascript编写的第一人称射击游戏
2007/02/25 Javascript
Jquery 表格合并的问题分享
2011/09/17 Javascript
jQuery事件绑定.on()简要概述及应用
2013/02/07 Javascript
JSON无限折叠菜单编写实例
2013/12/16 Javascript
jquery和css3实现的炫酷时尚的菜单导航
2014/09/01 Javascript
JavaScript判断textarea值是否为空并给出相应提示
2014/09/04 Javascript
jQuery源码分析之jQuery.fn.each与jQuery.each用法
2015/01/23 Javascript
JavaScript中Textarea滚动条不能拖动的解决方法
2015/12/15 Javascript
JavaScript的String字符串对象常用操作总结
2016/05/26 Javascript
JavaScript中两个字符串的匹配
2016/06/08 Javascript
BootStrap selectpicker后台动态绑定数据
2017/06/01 Javascript
nodejs对express中next函数的一些理解
2017/09/08 NodeJs
详解Vue中的MVVM原理和实现方法
2020/07/15 Javascript
js实现简易点击切换显示或隐藏
2020/11/29 Javascript
[03:34]2014DOTA2西雅图国际邀请赛 淘汰赛7月15日TOPPLAY
2014/07/15 DOTA
Python实现的一个找零钱的小程序代码分享
2014/08/25 Python
对python_discover方法遍历所有执行的用例详解
2019/02/13 Python
Python中如何使用if语句处理列表实例代码
2019/02/24 Python
详解Python数据可视化编程 - 词云生成并保存(jieba+WordCloud)
2019/03/26 Python
django获取from表单multiple-select的value和id的方法
2019/07/19 Python
Python内建序列通用操作6种实现方法
2020/03/26 Python
美国照明、家居装饰和家具购物网站:Bellacor
2017/09/20 全球购物
在C#中如何实现多态
2014/07/02 面试题
求职简历中个人的自我评价
2013/12/01 职场文书
课堂教学改革实施方案
2014/03/17 职场文书
函授生自我鉴定
2014/03/25 职场文书
法人授权委托书格式
2014/04/08 职场文书
给校长的建议书200字
2014/05/16 职场文书
法院反腐倡廉心得体会
2014/09/09 职场文书
高校自主招生教师推荐信
2015/03/23 职场文书
计划生育工作总结2015
2015/04/03 职场文书
Python基础之操作MySQL数据库
2021/05/06 Python
pytorch 中autograd.grad()函数的用法说明
2021/05/12 Python