zoukankan      html  css  js  c++  java
  • 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
  • 相关阅读:
    C++基础学习笔记----第十三课(操作符重载-下)
    SSH搭建
    java(17)
    英语语法检查软件
    Ubuntu sudo apt-get 安装下载更新软件包命令详解
    MATLAB:控制系统模型变换
    solvepnp
    MATLAB:控制系统模型变换
    MATLAB实现传递函数
    visual studio编译cmake opencv一直出错
  • 原文地址:https://www.cnblogs.com/yangWanSheng/p/11710773.html
Copyright © 2011-2022 走看看