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 相关文章推荐
js querySelector和getElementById通过id获取元素的区别
Apr 20 Javascript
让复选框只能选择一项的方法
Oct 08 Javascript
Jquery中offset()和position()的区别分析
Feb 05 Javascript
微信公众号开发 实现点击返回按钮就返回到聊天界面
Dec 15 Javascript
微信小程序-拍照或选择图片并上传文件
Jan 06 Javascript
jQuery简易时光轴实现方法示例
Mar 13 Javascript
zTree 树插件实现全国五级地区点击后加载的示例
Feb 05 Javascript
详解React+Koa实现服务端渲染(SSR)
May 23 Javascript
Vue3 中的数据侦测的实现
Oct 09 Javascript
微信浏览器左上角返回按钮监听的实现
Mar 04 Javascript
Vue项目前后端联调(使用proxyTable实现跨域方式)
Jul 18 Javascript
ES2020让代码更优美的运算符 (?.) (??)
Jan 04 Javascript
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
生成sessionid和随机密码的例子
2006/10/09 PHP
php socket客户端及服务器端应用实例
2014/07/04 PHP
PHP中文编码小技巧
2014/12/25 PHP
php 使用html5实现多文件上传实例
2016/10/24 PHP
php mysql数据库操作类(实例讲解)
2017/08/06 PHP
ecshop添加菜单及权限分配问题
2017/11/21 PHP
ThinkPHP框架中使用Memcached缓存数据的方法
2018/03/31 PHP
laravel项目利用twemproxy部署redis集群的完整步骤
2018/05/11 PHP
使用javascript获取flash加载的百分比的实现代码
2011/05/25 Javascript
分享JavaScript与Java中MD5使用两个例子
2015/12/23 Javascript
JCrop+ajaxUpload 图像切割上传的实例代码
2016/07/20 Javascript
分享bootstrap学习笔记心得(组件及其属性)
2017/01/11 Javascript
原生JS京东轮播图代码
2017/03/22 Javascript
JavaScript函数表达式详解及实例
2017/05/05 Javascript
vue.js实现的绑定class操作示例
2018/07/06 Javascript
微信小程序 wepy框架与iview-weapp的用法详解
2019/04/10 Javascript
微信小程序+腾讯地图开发实现路径规划绘制
2019/05/22 Javascript
axios如何利用promise无痛刷新token的实现方法
2019/08/27 Javascript
vue+elementui通用弹窗的实现(新增+编辑)
2021/01/07 Vue.js
vue form表单post请求结合Servlet实现文件上传功能
2021/01/22 Vue.js
python实现dict版图遍历示例
2014/02/19 Python
python实现在windows下操作word的方法
2015/04/28 Python
python 产生token及token验证的方法
2018/12/26 Python
python 字符串追加实例
2019/07/20 Python
分享PyCharm的几个使用技巧
2019/11/10 Python
Python模块zipfile原理及使用方法详解
2020/08/04 Python
Python调用jar包方法实现过程解析
2020/08/11 Python
linux mint中搜狗输入法导致pycharm卡死的问题
2020/10/28 Python
JD Sports比利时官网:英国领先的运动鞋和运动服饰零售商
2018/10/10 全球购物
小孩百日宴答谢词
2014/01/15 职场文书
考核工作实施方案
2014/03/30 职场文书
科技工作者先进事迹
2014/08/16 职场文书
债务授权委托书范本
2014/10/17 职场文书
物业客服专员岗位职责
2015/04/07 职场文书
《秦兵马俑》教学反思
2016/02/24 职场文书
Python利用FlashText算法实现替换字符串
2022/03/31 Python