分享web开发知识

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

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

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

发布时间:2023-09-06 01:41责任编辑:顾先生关键词:暂无标签

在JavaScript中变量包含两种类型的值:一种是基本类型,一种是引用类型。

基本类型包括:数值、字符串、null、undefined、布尔值
引用类型包括:对象、数组、函数、正则…

1.引用类型的动态属性

对于引用类型的值,我们可以为其添加属性和方法,也可以改变或删除属性和方法,

对于基本类型的值,尽管给其添加属性和方法不会报错,但这是无效的。

var obj=new Object();obj.name="zuobaiquan";var str="zbq";str.age=20;console.log(obj.name);// zuobaiquanconsole.log(str.age);// undefined

2.基本类型值和引用类型值的复制

2.1基本类型值

基本类型值是指在栈内存保存的简单数据段,在复制基本类型值的时候,会开辟出一个新的内存空间,将值复制到新的内存空间。

var a = 1;var b = a;a = 2;console.log(a);//输出2;console.log(b);//输出1;

var a = 1;

var b = a;

a = 2;

从上面例子看出,当一个变量的值是基本类型,把它复制给另一个变量,复制完成后改变它的值,不会影响已经复制了它的值的变量。

2.1引用类型值

引用类型值是保存在堆内存中的对象,变量保存的只是指向该内存的地址,在复制引用类型值的时候,其实只复制了指向该内存的地址。

var a = { ??name: ‘Kitty‘, ??age: ‘20‘, ??sex: ‘man‘};var b = a;a.name = ‘Jack‘;console.log(a);//输出{name: ‘Jack‘,age: 20,sex: ‘man‘}console.log(b);//输出{name: ‘Jack‘,age: 20,sex: ‘man‘}

var a = {name: ‘Kitty’,age: ‘20’,sex: ‘man’};

var b = a;

a.name = ‘Jack’;

从上面例子看出,当一个变量的值是引用类型值,把它复制给另外一个变量,复制的只是指向储存对象内存的地址,所以复制完成后,改变它的值,会影响复制了它的值的变量。
注意:如果有两个变量的值是引用类型值,就算它们的值完全相同,它们也是不相等的,因为它们指向的内存地址不同,例子:

3.对象的浅拷贝和深拷贝

当一个变量是对象,如果像上面那样直接将一个变量赋值给另一个变量,如果改变某个变量的值,另外一个变量也会跟着改变,如果我们不想发生这种情况,就需要写一个函数用来拷贝对象。

3.1浅拷贝

当对象里的属性的值只有基本类型的值时候。

var a = { ????name: ‘Kitty‘, ????age: 12, ????sex: ‘man‘}function copy(obj){ ???var newObj = {}; ???for(vl in obj){ ????????newObj[vl] = obj[vl] ????} ???return newObj;}

例子:

从上面例子看到,我们通过这种方式拷贝对象,改变某个变量的值,并不会影响另一个变量。

3.1深拷贝

当对象里的属性的值还是一个对象,这时候用上面的方法就不行了,例子:

这时候要改进这个函数:

使用递归的方法:

function deepCopy(obj){ ????var newObj = {}; ????for(vl in obj){ ????????if(typeof obj[vl] === ‘object‘ && obj[vl] !== null){ ????????????newObj[vl] = deepCopy(obj[vl]); ????????}else{ ????????????newObj[vl] = obj[vl]; ????????} ???????????} ????return newObj;}

例子:

使用JSON的方法:

JSON.stringify(),将一个对象解析成字符串。
JSON.parse(),从一个字符串中解析出json 对象。

我们可以使用上面两个个方法来进行对象的深拷贝:

JSON.paese(JSON.stringify());

例子:

参考:http://www.cnblogs.com/lijiayi/p/jsdeeepcopy.html

如果 觉得文章不错,可以请博主喝一杯奶茶哦!!!

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

原文地址:https://www.cnblogs.com/zuobaiquan01/p/8414306.html

知识推荐

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