温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
  • 忘记密码?
登录注册×
获取短信验证码
其他方式登录
点击 登录注册 即表示同意 《亿速云用户服务条款》
  • 服务器
  • 数据库
  • 开发技术
  • 网络安全
  • 互联网科技
登 录 注册有礼
最新更新 网站标签 地图导航
产品
  • 首页 > 
  • 教程 > 
  • 开发技术 > 
  • web开发 > 
  • 如何理解JavaScript中的深拷贝和浅拷贝

如何理解JavaScript中的深拷贝和浅拷贝

发布时间:2020-04-16 10:24:54 来源:亿速云 阅读:157 作者:小新 栏目: web开发

今天小编给大家分享的是如何理解JavaScript中的深拷贝和浅拷贝,很多人都不太了解,今天小编为了让大家更加了解JavaScript中的深拷贝和浅拷贝,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。

对于 数字,boolean 和 字符串 等基本类型 而言,赋值、浅拷贝和深拷贝无意义,因为每次都会在堆中开辟一块新的空间,指向新的地址。

一、赋值:

指向同一个地址,不拷贝。
如何理解JavaScript中的深拷贝和浅拷贝

var obj1 = {name:'圆', radius:10, point:{x:0,y:0}};
var obj2 = obj1;
 
obj2.name = "圆2";  //obj1中的name也会变

二、浅拷贝:

如何理解JavaScript中的深拷贝和浅拷贝

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}

三、深拷贝:

如何理解JavaScript中的深拷贝和浅拷贝

方法1

JSON.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等库

//jquery
let  y = $.extend(true,{},x)   //第一个参数 必须为true

//lodash库
let  y = _.cloneDeep(x);

关于如何理解JavaScript中的深拷贝和浅拷贝就分享到这里了,当然并不止以上和大家分析的办法,不过小编可以保证其准确性是绝对没问题的。希望以上内容可以对大家有一定的参考价值,可以学以致用。如果喜欢本篇文章,不妨把它分享出去让更多的人看到。

向AI问一下细节
推荐阅读:
  1. JavaScript深拷贝与浅拷贝
  2. JavaScript中浅拷贝和深拷贝的原理是什么

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

javascript avascript ava
  • 上一篇新闻:
    CSS对TD中INPUT的宽度设置方法
  • 下一篇新闻:
    如何利用HTML+CSS制作简单的下拉菜单

猜你喜欢

  • linux怎么杀死进程并重启程序
  • python怎么删除文件夹下的所有文件
  • php中sleep函数不执行怎么解决
  • Spark和Hadoop的应用场景有哪些
  • C++怎么用类实现链表
  • Java如何获取指定时间
  • linux中怎么强制结束进程
  • Python怎么向列表中添加整数
  • php中sleep函数的使用方法是什么
  • neo4j的应用场景有哪些
最新资讯
  • Django的信号机制是什么如何使用
  • Django中的中间件是如何工作的有哪些常见的应用场景
  • Django如何管理静态文件和媒体文件
  • Django的admin站点如何定制和扩展
  • Django的表单是如何使用的
  • 如何使用Django的ORM进行数据库操作
  • Django的URL配置是如何工作的
  • Django的视图和模板之间有何区别
  • Django中的模型是什么如何定义
  • Django框架的MTV设计模式是如何工作的
相关推荐
  • javascript深拷贝和浅拷贝详解
  • JavaScript对象的深拷贝和浅拷贝总结
  • javascript中怎么区分浅拷贝和深拷贝并实现深拷贝
  • 如何理解JavaScript中的浅拷贝与深拷贝
  • 怎么理解Javascript深拷贝与浅拷贝
  • JavaScript中的深拷贝和浅拷贝的详细介绍
  • 如何理解Java的浅拷贝和深拷贝
  • 分析JavaScript浅拷贝和深拷贝
  • JavaScript深拷贝和浅拷贝如何使用
  • Java中浅拷贝和深拷贝该怎么理解

相关标签

javascript对象 何为javascript原型?读完你就明 javascript函数 javascript/jquery javascript javascript对象 何为javascript原型?读完你就明 javascript函数 javascript/jquery java教程 java servlet java运算符 java内部类 java-web weixin-java-miniapp javax.servlet
AI

深圳SEO优化公司茂名网站优化软件哪家好钦州优化推荐泉州网站设计多少钱吉林百度seo长沙网站推广工具哪家好梧州模板网站建设温州外贸网站建设推荐桐城网站seo优化公司平凉网站优化排名推荐芜湖seo网站优化推荐驻马店网络推广价格铜陵品牌网站设计推荐信阳网站优化软件报价固原模板推广哪家好湖州网站搭建价格重庆网页制作哪家好兴安盟网站搜索优化上海网站搭建推荐大芬关键词排名包年推广多少钱朔州百搜标王公司南通如何制作网站多少钱松岗品牌网站设计报价延边seo排名哪家好黄山设计公司网站价格新乡外贸网站设计哪家好横岗模板推广报价衡水百度竞价包年推广多少钱延安SEO按天计费公司商洛百度爱采购报价唐山seo网站推广多少钱歼20紧急升空逼退外机英媒称团队夜以继日筹划王妃复出草木蔓发 春山在望成都发生巨响 当地回应60岁老人炒菠菜未焯水致肾病恶化男子涉嫌走私被判11年却一天牢没坐劳斯莱斯右转逼停直行车网传落水者说“没让你救”系谣言广东通报13岁男孩性侵女童不予立案贵州小伙回应在美国卖三蹦子火了淀粉肠小王子日销售额涨超10倍有个姐真把千机伞做出来了近3万元金手镯仅含足金十克呼北高速交通事故已致14人死亡杨洋拄拐现身医院国产伟哥去年销售近13亿男子给前妻转账 现任妻子起诉要回新基金只募集到26元还是员工自购男孩疑遭霸凌 家长讨说法被踢出群充个话费竟沦为间接洗钱工具新的一天从800个哈欠开始单亲妈妈陷入热恋 14岁儿子报警#春分立蛋大挑战#中国投资客涌入日本东京买房两大学生合买彩票中奖一人不认账新加坡主帅:唯一目标击败中国队月嫂回应掌掴婴儿是在赶虫子19岁小伙救下5人后溺亡 多方发声清明节放假3天调休1天张家界的山上“长”满了韩国人?开封王婆为何火了主播靠辱骂母亲走红被批捕封号代拍被何赛飞拿着魔杖追着打阿根廷将发行1万与2万面值的纸币库克现身上海为江西彩礼“减负”的“试婚人”因自嘲式简历走红的教授更新简介殡仪馆花卉高于市场价3倍还重复用网友称在豆瓣酱里吃出老鼠头315晚会后胖东来又人满为患了网友建议重庆地铁不准乘客携带菜筐特朗普谈“凯特王妃P图照”罗斯否认插足凯特王妃婚姻青海通报栏杆断裂小学生跌落住进ICU恒大被罚41.75亿到底怎么缴湖南一县政协主席疑涉刑案被控制茶百道就改标签日期致歉王树国3次鞠躬告别西交大师生张立群任西安交通大学校长杨倩无缘巴黎奥运

深圳SEO优化公司 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化