在实际开发中遇到过太多次深拷贝浅拷贝的问题。总结一下~

JS数据存储和深浅拷贝实际运用①

这是之前写过的一篇文章,解决浅拷贝深拷贝的问题只说了一种方法,今天来补充一下。

介绍深拷贝和浅拷贝都在上一篇文章里介绍过了,在上一篇文章里只写了一个针对于数组的一种深拷贝,今天总结一下 js中对象和数组的深浅拷贝。具体的场景已经在上一篇文章里说明了。

这里废话一下上一篇文章中出现的问题:一个表格数据,可以点击编辑弹出表单数据,修改数据后点击取消或者关闭表单时,表格的数据会变空,解决的思路就是当我点击表单显示的时候,定义一个中间变量存储当前表单的数据。点击取消按钮或者关闭表单时,把之前定义的这个中间变量重新赋值给当前的表单数据。就可以解决啦~
当然这个问题还是由于对象或者数组的深浅拷贝的问题。所以今天来总结一下对象和数组的深拷贝和浅拷贝的常用方法。

首先来介绍一下对象的浅拷贝

1.最传统的浅拷贝

 var gogo = {
name: '小明',
}
var out = {}
out = gogo
console.log(gogo) //{name: "小明"}
console.log(out) //{name: "小明"}
out.name = '小花花'
console.log(gogo) //{name: "小花花"}
console.log(out) //{name: "小花花"}

  

当我改变out的值的时候gogo里也改变了~
2.Object.assign()
这个方法是es6的新方法,用于对象的合并,将源对象(source)的所有可枚举属性,复制到目标对象(target)。目标对象就是Object.assign(),括号里的第一个参数。

注意,Object.assign可以用来处理数组,但是会把数组视为对象。

说完了对象的浅拷贝说一下深拷贝
1.转换成json再转换成对象实现对象的完全深拷贝(此方法适用于数组的深拷贝,也是比较简单快速的深拷贝方法)

var out= {
name: '小花花',
sex: 'man',
old: '18'
}
var gogo= JSON.parse(JSON.stringify(out))

  

这种方式目前是最受推崇的完全深拷贝写法。
但是这样容易造成数据丢失,因为如果对象中含有Date, function, undefined, Infinity, RegExp, Map, Set, Blob, FileList, ImageData, sparse Array, Typed Array等复杂对象的话,转化成json再转回来后这些数据都丢失了。。。

2.扩展运算符

var out= {
name: '小花花',
sex: 'man',
old: '18'
}
var { ...gogo} = out
console.log(gogo) //{name: "小花花", sex: "man", old: "18"}
console.log(out) //{name: "小花花", sex: "man", old: "18"}
out.name = '大花花花花花'
console.log(gogo) //{name: "小花花", sex: "man", old: "18"}
console.log(out) // { name: "大花花花花花", sex: "man", old: "18" }

  

介绍完对象的深浅拷贝之后接下来说一下数组

  1. concat() slice() 实现一维数组的深拷贝,多维数组不行。

    var array1 = ['a',1,true,{name:'lei',age:18}];
    
    //concat()  slice() 实现浅拷贝
    
    var array2 = array1.concat()
    
    //修改拷贝后的数据
    
    array2[0] = 'b';            //array1[0]是原始数据类型 所以是直接赋值的
    
    array2[3].name = 'zhang';   //array1[3]是对象数据类型 所以拷贝的是对象的引用,其实还是和原数组使用同一对象
    
    console.log(array1);   //  ['a',1,true,{name:'zhang',age:18}]
    

      

    2.递归(目前有点难度所以以后再补充) 深拷贝

    3.针对于多维数组的jq方法 深拷贝
    jQuery.extend()

    传送门:https://www.runoob.com/jquery/misc-extend.html

JS对象和数组深浅拷贝总结②的更多相关文章

  1. 关于:1.指针与对象;2.深浅拷贝(复制);3.可变与不可变对象;4.copy与mutableCopy的一些理解

    最近对深浅拷贝(复制)做了一些研究,在此将自己的理解写下来,希望对大家有所帮助.本人尚处在摸索阶段,希望各位予以指正. 本文包括如下方向的探索: 1.指针与对象: 2.深/浅拷贝(复制): 3.可变/ ...

  2. JS基本类型-引用类型-深浅拷贝

    在JavaScript中变量包含两种类型的值:一种是基本类型,一种是引用类型. 基本类型包括:数值.字符串.null.undefined.布尔值引用类型包括:对象.数组.函数.正则… 补充: null ...

  3. JS对象和数组在谷歌浏览器中引用存储的表现

    大家都知道JS的数据分为基本类型和引用类型.具体什么不说了,今天主要说说对象和数组作为引用类型在谷歌浏览器中的表现. 首先,问题是这么发现的.我在控制台使用console打印了一个数组,然后对数组进行 ...

  4. JS的赋值与深浅拷贝实例

    赋值 基本类型: 传值,在栈内存中的数据发生数据变化的时候,系统会自动为新的变量分配一个新的之值在栈内存中,两个变量相互独立,互不影响的 引用类型: 传址,只改变指针的指向,指向同一个对象,两个变量相 ...

  5. js 对象,数组,字符串,相互转换

    1:对象转换数组 let obj = {'val1':1, 'val2':2, 'val3':3, 'val4':4}; var arr = [] for (let i in obj) { //取键 ...

  6. js对象及元素复制拷贝

    1.数组及对象拷贝: 浅拷贝var b=$.extend(false,{},a);//对象浅拷贝 var a={aa:111,bb:{bb1:22}}; var b=$.extend(false,{} ...

  7. 检测js对象是不是数组类型?

    面试时候被人问如何检测一个未知变量是不是数组类型,丢脸啊,老祖宗的脸都丢没了,这都不会,回家啃书本去吧!!! var a = [];方法一:Array.isArray([])  //true type ...

  8. js对象、数组转换字符串

    对象转换成字符串需要使用toString()方法. 1 var a = function(){ 2 console.log(111); 3 }; 4 var b = a.toString(); 5 c ...

  9. js对象跟数组多层嵌套,检测没有此数据就添加有则不添加以及超过限制条件删除操作

    例如你需要这样格式的数据: [{"name":"合肥市","arrey":[{"lat":"31.862323 ...

随机推荐

  1. thinkphp扩展配置

    扩展配置可以支持自动加载额外的自定义配置文件,并且配置格式和项目配置一样. 设置扩展配置的方式如下(多个文件用逗号分隔): // 加载扩展配置文件 'LOAD_EXT_CONFIG' => 'u ...

  2. angular2 组件内容嵌入(ng-content)

    一.简介 内容嵌入是组件的一个高级功能特性,使用组件的内容嵌入特性能很好地扩充组件的功能,方便代码的复用. 二.用法 如上,在模版中使用了<ng-content>标签,这个标签就是用来渲染 ...

  3. JavaScript中的表单编程

    表单编程 1获取表单相关信息 1.什么是表单元素 1.什么是表单元素 在H TML中表单就是指form标签,它的作用是将用户输入或选择的数据提交给指定的服务器 2.如何获取表单元素 <form ...

  4. MR 原理

    MapReduce的执行步骤: 1.Map任务处理 1.1 读取HDFS中的文件.每一行解析成一个<k,v>.每一个键值对调用一次map函数.                <0,h ...

  5. Classpath in jar关于java加载第三方jar的集中方法和详细解释。

    转载地址:http://www.iteye.com/topic/332580 大家都知道一个java应用项目可以打包成一个jar,当然你必须指定一个拥有main函数的main class作为你这个ja ...

  6. hdu-4893

    http://acm.hdu.edu.cn/showproblem.php?pid=1394 题意: 给定一个数组a,一开始数组里面的元素都是0,现在有三个操作: 操作1:给第k个数字加上d. 操作2 ...

  7. D3.js+Es6+webpack构建人物关系图(力导向图)

    功能列表:1. 增加下载SVG转PNG功能,图片尺寸超出可视区域也能够下载全部显示出来2. 增加图谱放大缩小平移功能3. 增加图谱初始化加载时自动缩放功能4. 增加导出excel功能,配合后台工具类达 ...

  8. [WPF自定义控件库] 让Form在加载后自动获得焦点

    原文:[WPF自定义控件库] 让Form在加载后自动获得焦点 1. 需求 加载后让第一个输入框或者焦点是个很基本的功能,典型的如"登录"对话框.一般来说"登录" ...

  9. C++函数或者命名空间前面加::

    命名空间和函数前面加上:: 经常看到命名空间前就只有:: 比如  ::test;这种代表是全局的test 比如  ::CreateDirectory(..),代表使用系统API也就是全局的 避免使用到 ...

  10. 记mysql 启动不了了的解决方法

    系统: centos7 本地的环境,mysql启动不了,查看 /var/log/mysqld.log 有以下内容 2018-12-24T08:05:38.090527Z 0 [Warning] TIM ...