• object.assign


    MDN上这样介绍Object.assign(),'Object.assign() 方法用于将所有可枚举的属性的值从一个或多个源对象复制到目标对象。它将返回目标对象',好吧,并看不出是深拷贝还是浅拷贝,我们来测试一下

    srcObj = {'name': '明', grade: {'chi': '50', 'eng': '50'} };
    copyObj2 = Object.assign({}, srcObj);
    copyObj2.name = '红';
    copyObj2.grade.chi = '60';
    console.log('新 objec srcObj', srcObj);  // { name: '明', grade: { chi: '60', eng: '50' } }

    从例子中可以看出,改变复制对象的name 和 grade.chi ,源对象的name没有变化,但是grade.chi却被改变了。因此我们可以看出Object.assign()拷贝的只是属性值,假如源对象的属性值是一个指向对象的引用,它也只拷贝那个引用值。
    也就是说,对于Object.assign()而言, 如果对象的属性值为简单类型(string, number),通过Object.assign({},srcObj);得到的新对象为‘深拷贝’;如果属性值为对象或其它引用类型,那对于这个对象而言其实是浅拷贝的。这是Object.assign()特别值得注意的地方。
    多说一句,Object.assign({}, src1, src2); 对于scr1和src2之间相同的属性是直接覆盖的,如果属性值为对象,是不会对对象之间的属性进行合并的。

    JSON.parse() 和 JSON.stringify()

    JSON.parse() 和 JSON.stringify() 算是对 深拷贝的一个无脑实现,看例子

    srcObj = {'name': '明', grade: {'chi': '50', 'eng': '50'} };
    // copyObj2 = Object.assign({}, srcObj);
    copyObj2 = JSON.parse(JSON.stringify(srcObj));
    copyObj2.name = '红';
    copyObj2.grade.chi = '60';
    console.log('JSON srcObj', srcObj); // { name: '明', grade: { chi: '50', eng: '50' } }
    可以看到改变copyObj2并没有改变原始对象,实现了基本的深拷贝。
    但是用JSON.parse()和JSON.stringify()会有一个问题。
    JSON.parse()和JSON.stringify()能正确处理的对象只有Number、String、Array等能够被json表示的数据结构,因此函数这种不能被json表示的类型将不能被正确处理。比如
    rcObj = {'name': '明', grade: {'chi': '50', 'eng': '50'},
        'hello': function() {console.log('hello')}};
    // copyObj2 = Object.assign({}, srcObj);
    copyObj2 = JSON.parse(JSON.stringify(srcObj));
    copyObj2.name = '红';
    copyObj2.grade.chi = '60';
    console.log('JSON srcObj', copyObj2); //{ name: '红', grade: { chi: '60', eng: '50' } }
     
  • 相关阅读:
    App测试从入门到精通之安装、卸载和运行测试
    App测试从入门到精通之App分类和场景操作系统
    一步到位带你入门Selenium
    MAMP和WAMP搭建Web环境,数据库,数据分布可视化
    爬虫 Http请求,urllib2获取数据,第三方库requests获取数据,BeautifulSoup处理数据,使用Chrome浏览器开发者工具显示检查网页源代码,json模块的dumps,loads,dump,load方法介绍
    Python 基本语法,文件读写,数据结构和类型
    python 数据工程 and 开发工具Sublime
    jieba user guide
    python各类项目模块记录
    python parse xml using DOM
  • 原文地址:https://www.cnblogs.com/zhx119/p/12597058.html
Copyright © 2020-2023  润新知