美文网首页
项目开发中 常用es6--API【必会之对象的拓展符】人送外号

项目开发中 常用es6--API【必会之对象的拓展符】人送外号

作者: 一只大橘 | 来源:发表于2019-08-14 16:01 被阅读0次

    es6中的三个点到底是用来做什么的?到底是龙是马拉出来溜溜。。。

    对象的拓展运算符
    拓展运算符(...)用于取出参数对象所有可遍历属性然后拷贝到当前对象。

    基本用法
    let person = {name: "Amy", age: 15};
    let someone = { ...person };
    someone;  //{name: "Amy", age: 15}
    可用于合并两个对象
    let age = {age: 15};
    let name = {name: "Amy"};
    let person = {...age, ...name};
    person;  //{age: 15, name: "Amy"}
    

    注意点
    自定义的属性和拓展运算符对象里面属性的相同的时候:自定义的属性在拓展运算符后面,则拓展运算符对象内部同名的属性将被覆盖掉。

    let person = {name: "Amy", age: 15};
    let someone = { ...person, name: "Mike", age: 17};
    someone;  //{name: "Mike", age: 17}
    

    自定义的属性在拓展运算度前面,则变成设置新对象默认属性值。

    let person = {name: "Amy", age: 15};
    let someone = {name: "Mike", age: 17, ...person};
    someone;  //{name: "Amy", age: 15}
    

    拓展运算符后面是空对象,没有任何效果也不会报错。

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

    拓展运算符后面是null或者undefined,没有效果也不会报错。

    let b = {...null, ...undefined, a: 1, b: 2};
    b;  //{a: 1, b: 2}
    

    参考API:
    https://www.runoob.com/w3cnote/deconstruction-assignment.html

    相关文章

      网友评论

          本文标题:项目开发中 常用es6--API【必会之对象的拓展符】人送外号

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