美文网首页
Vue - 使用Lodash进行深拷贝

Vue - 使用Lodash进行深拷贝

作者: 西半球_ | 来源:发表于2021-12-20 18:37 被阅读0次

    GitHub Demo 地址

    在线预览

    Lodash 官网

    浅拷贝 : 只是将数据中所有的数据引用下来,依旧指向同一个存放地址,拷贝之后的数据修改之后,也会影响到原数据的中的对象数据。例如:Object.assign(),...扩展运算符

    深拷贝: 将数据中所有的数据拷贝下来,对拷贝之后的数据进行修改不会影响到原数据。

    • JSON.parse(JSON.stringify(obj))深拷贝的问题

    1、如果obj里面存在时间对象,JSON.parse(JSON.stringify(obj))之后,时间对象变成了字符串。
    2、如果obj里有RegExp、Error对象,则序列化的结果将只得到空对象。
    3、如果obj里有函数,undefined,则序列化的结果会把函数, undefined丢失。
    4、如果obj里有NaN、Infinity和-Infinity,则序列化的结果会变成null。
    5、JSON.stringify()只能序列化对象的可枚举的自有属性。如果obj中的对象是有构造函数生成的, 则使用JSON.parse(JSON.stringify(obj))深拷贝后,会丢弃对象的constructor。
    6、如果对象中存在循环引用的情况也无法正确实现深拷贝。

    Lodash 安装

    浏览器环境:

    <script src="lodash.js"></script>
    

    通过 npm:

    $ npm i -g npm
    $ npm i --save lodash
    

    Lodash使用

    import lodash from 'lodash'
    
    lodash.cloneDeep(objects)
    

    相关文章

      网友评论

          本文标题:Vue - 使用Lodash进行深拷贝

          本文链接:https://www.haomeiwen.com/subject/txugfrtx.html