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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
· 【译】Visual Studio 中新的强大生产力特性
· 2025年我用 Compose 写了一个 Todo App