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 实现菜单上下显示附效果图
Nov 21 Javascript
Javascript中的apply()方法浅析
Mar 15 Javascript
jquery读取xml文件实现省市县三级联动的方法
May 29 Javascript
JS实现为排序好的字符串找出重复行的方法
Mar 02 Javascript
基于JavaScript实现 网页切出 网站title变化代码
Apr 03 Javascript
JavaScript学习小结之使用canvas画“哆啦A梦”时钟
Jul 24 Javascript
Angular.js中$resource高大上的数据交互详解
Jul 30 Javascript
VUE页面中加载外部HTML的示例代码
Sep 20 Javascript
vue-scroller记录滚动位置的示例代码
Jan 17 Javascript
vue页面跳转后返回原页面初始位置方法
Feb 11 Javascript
在微信小程序中渲染HTML内容3种解决方案及分析与问题解决
Jan 12 Javascript
JS倒计时两种实现方式代码实例
Jul 27 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
比较全面的PHP数组的使用方法小结
2010/09/23 PHP
详解PHP数组赋值方法
2015/11/07 PHP
PHP5.4起内置web服务器使用方法
2016/08/09 PHP
PHP入门教程之数学运算技巧总结
2016/09/11 PHP
PHP实现的微信公众号扫码模拟登录功能示例
2019/05/30 PHP
php用wangeditor3实现图片上传功能
2019/08/22 PHP
Jquery 组合form元素为json格式,asp.net反序列化
2009/07/09 Javascript
Javascript异步编程的4种方法让你写出更出色的程序
2013/01/17 Javascript
javascript中拼接HTML字符串的最快、最好的方法
2014/06/07 Javascript
WEB前端设计师常用工具集锦
2014/12/09 Javascript
Angular Js文件上传之form-data
2015/08/28 Javascript
jQuery绑定自定义事件的魔法升级版
2016/06/30 Javascript
jQuery dateRangePicker插件使用方法详解
2017/07/28 jQuery
JS+jQuery实现注册信息的验证功能
2017/09/26 jQuery
Angular使用过滤器uppercase/lowercase实现字母大小写转换功能示例
2018/03/27 Javascript
webpack的CSS加载器的使用
2018/09/11 Javascript
vuejs router history 配置到iis的方法
2018/09/20 Javascript
JS中创建自定义类型的常用模式总结【工厂模式,构造函数模式,原型模式,动态原型模式等】
2019/01/19 Javascript
基于JavaScript实现大文件上传后端代码实例
2020/08/18 Javascript
vue实现单一筛选、删除筛选条件
2020/10/26 Javascript
[02:41]DOTA2英雄基础教程 亚巴顿
2014/01/02 DOTA
python使用webbrowser浏览指定url的方法
2015/04/04 Python
Python操作mongodb数据库进行模糊查询操作示例
2018/06/09 Python
Python实现动态添加属性和方法操作示例
2018/07/25 Python
python 对给定可迭代集合统计出现频率,并排序的方法
2018/10/18 Python
Django Celery异步任务队列的实现
2019/07/24 Python
jupyter notebook中新建cell的方法与快捷键操作
2020/04/22 Python
Python如何生成xml文件
2020/06/04 Python
CSS3与动画有关的属性transition、animation、transform对比(史上最全版)
2017/08/18 HTML / CSS
澳洲的服装老品牌:SABA
2018/02/06 全球购物
企业口号大全
2014/06/12 职场文书
学生党员一帮一活动总结
2014/07/08 职场文书
2014年信访维稳工作总结
2014/12/08 职场文书
教师个人工作总结范文2015
2015/10/14 职场文书
只用40行Python代码就能写出pdf转word小工具
2021/05/31 Python
Vue Element-ui表单校验规则实现
2021/07/09 Vue.js