• ES6解构赋值


    ES6结构赋值

      左右两边结构一样,声明和赋值不能分开必须要再同一行的代码里面

      1、数组模型的解构

    let arr = [1, 2, 3];
    let a = arr[0];
    let b = arr[1];
    let c = arr[2];
    console.log(a, b, c); // 1 ,2 ,3
    let [a, b, c] = [1, 2, 3];
    console.log(a, b, c); // 1 2 3
    // 嵌套
    let [a, [[b], c]] = [1, [[2], 3]];
    console.log(a, b, c); // 1 2 3
    // 忽略
    let [a, , b] = [1, 2, 3];
    console.log(a, b); // 1  3
    // 不完全解构
    let [a = 1, b] = []; 
    console.log(a, b); // a = 1, b = undefined
    // 剩余运算符
    let {a, b, ...rest} = {a: 10, b: 20, c: 30, d: 40};
    // a = 10
    // b = 20
    // rest = {c: 30, d: 40}

      2、json解构

    let {a, b, c} = {a: 1, b: 2, c: 3};
    console.log(a, b, c); // 1 2 3
    let [{a, b}, [n1, n2], num, str] = [{a: 1, b: 2}, [3, 4], 5, '6'];
    console.log(a, b, n1, n2, num, str); // 1 2 3 4 5 "6"
    let [json, arr, num, str] = [{a: 1, b: 2}, [3, 4], 5, '6'];
    console.log(json, arr, num, str); // {a: 1, b: 2} (2) [3, 4] 5 "6"

      3、解构,默认值

    let {a = 10, b = 5} = {a: 3};
    // a = 3; b = 5;
    let {a: aa = 10, b: bb = 5} = {a: 3};
    // aa = 3; bb = 5;

      当解构模式有匹配结果,且匹配结果是 undefined 时,会触发默认值作为返回结果。

    let [a = 3, b = a] = [];     // a = 3, b = 3 a 与 b 匹配结果为 undefined ,触发默认值:a = 3; b = a =3
    let [a = 3, b = a] = [1];    // a = 1, b = 1 a 正常解构赋值,匹配结果:a = 1,b 匹配结果 undefined ,触发默认值:b = a =1
    let [a = 3, b = a] = [1, 2]; // a = 1, b = 2 a 与 b 正常解构赋值,匹配结果:a = 1,b = 2

      4、注意事项

    // 左边为数组,右边为json,两边的结构不一样
    let [a, b] = {a: 12, b: 34};
    console.log(a, b); // 出错
    // 右边类型错误,{12, 34} json写法错误
    let {a, b} = {12, 34};
    console.log(a, b); // Uncaught SyntaxError: Unexpected token 
    // 声明和赋值分开
    let [a, b];
    [a , b] = {12, 34};
    console.log(a, b); // Uncaught SyntaxError: Missing initializer in destructuring declaration
  • 相关阅读:
    逛画展
    数的划分
    有点难度的树链刨分
    树链刨分
    记502 dp专练
    数论相关
    模拟退火
    仓鼠找sugar
    NOIP 2017 解题报告
    整体二分
  • 原文地址:https://www.cnblogs.com/yangWanSheng/p/11710773.html
Copyright © 2020-2023  润新知