您好,欢迎访问一九零五行业门户网

JavaScript中深拷贝和浅拷贝的深入理解(代码示例)

本篇文章给大家带来的内容是关于javascript中深拷贝和浅拷贝的深入理解(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
对于 数字,boolean 和 字符串 等基本类型 而言,赋值、浅拷贝和深拷贝无意义,因为每次都会在堆中开辟一块新的空间,指向新的地址。
一、赋值:
指向同一个地址,不拷贝。
var obj1 = {name:'圆', radius:10, point:{x:0,y:0}};var obj2 = obj1; obj2.name = 圆2;  //obj1中的name也会变
二、浅拷贝:
var obj1 = {name:'圆', radius:10, point:{x:0,y:0}};var obj2 = object.assign({},obj1); obj2.name=圆2  // obj1.name不会变obj2.point.x = 2       //obj1.point.x 改变,因为只拷贝到point一层同样,解构赋值也是如此var obj1 = {name:'圆', radius:10, point:{x:0,y:0}};var obj2 = {…obj1}
三、深拷贝:
方法1json.stringify(obj)  先将对象转换为字符串
json.parse(str)      然后再将字符串转为对象。
var obj1 = {name:'圆', radius:10, point:{x:0,y:0}};var obj2 = json.stringify(obj1 );var obj1 = json.parse(obj2); obj2.name = 圆2;  // obj1 不变obj2.point.x = 3;     //  obj1 不变
但json.stringify在转换date,regexp对象及function时会出现问题,同时也会忽略undefined、function。
//date 类型var o = new date();console.log(o.tostring());         //  mon nov 06 2017 11:23:35 gmt+0800 (china standard time)  本地标准时间console.log(json.stringify(o));    // 2017-11-06t03:23:35.547z  国际标准时间
因为stringify默认调用的是object的tojson方法,所以重写date的tojson,然后stringify就是ok的。
date.prototype.tojson = function () {  return this.tolocalestring();}console.log(json.stringify(o));      // 11/6/2017, 11:23:35 am
同理regexp
//regexp类型r1 = /\d+/;console.log(json.stringify(r1));           //   {} regexp.prototype.tojson = function(){return this.tostring();}console.log(json.stringify(r1));          //    /\\d+/
方法2类库的方式。jquery,lodash等库//jquerylet  y = $.extend(true,{},x)   //第一个参数 必须为true//lodash库let  y = _.clonedeep(x);
以上就是javascript中深拷贝和浅拷贝的深入理解(代码示例)的详细内容。
其它类似信息

推荐信息