美文网首页
ES6扩展运算符 三个点(...)

ES6扩展运算符 三个点(...)

作者: CXYMichael | 来源:发表于2019-02-24 22:38 被阅读0次

    理解对象的扩展运算符其实很简单,只要记住一句话就可以:

    对象中的扩展运算符(...)用于取出参数对象中的所有可遍历属性,拷贝到当前对象之中

    let bar = { a: 1, b: 2 };
    let baz = { ...bar }; // { a: 1, b: 2 }
    

    上述方法实际上等价于:

    let bar = { a: 1, b: 2 };
    let baz = Object.assign({}, bar); // { a: 1, b: 2 }
    

    Object.assign方法用于对象的合并,将源对象(source)的所有可枚举属性,复制到目标对象(target)。Object.assign方法的第一个参数是目标对象,后面的参数都是源对象。(如果目标对象与源对象有同名属性,或多个源对象有同名属性,则后面的属性会覆盖前面的属性)。同样,如果用户自定义的属性,放在扩展运算符后面,则扩展运算符内部的同名属性会被覆盖掉。

    let bar = {a: 1, b: 2};
    let baz = {...bar, ...{a:2, b: 4}};  // {a: 2, b: 4}
    

    那如果扩展的是一个复杂对象呢?

    let bar = { a: 1, b: { c: 2 } };
    let baz = { ...bar }; //{ a: 1, b: { c: 2 } }
    bar.a = 2;
    bar.b.c = 5;
    console.log(baz); // { a: 1, b: { c: 5 } }
    baz.b = { d: 1 };
    console.log(bar); // { a: 2, b: { c: 5 } }
    

    可以发现,扩展运算实际上是遍历源对象的属性并浅拷贝到目标对象中,所以如果要实现深拷贝还是需要序列化+反序列化或者extend函数。

    相关文章

      网友评论

          本文标题:ES6扩展运算符 三个点(...)

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