什么是解构?

什么是解构?

解构简而言之就是按照一定的规则,从数组或者对象中提取值,赋值给变量,使其能够轻松得到想要的值

接下来我们来举一些例子:

1.数组的解构:

javascript 复制代码
//声明两个数组:
    let arr = ["李白", "韩信", "诸葛亮"];
    let arr1 = [["李白", "韩信"], "诸葛亮"];

这时我们想要拿到 数组中的 :"李白" 原来的方式:

javascript 复制代码
//一维数组arr:
    let Hore = arr[0];
       console.log(Hore);//"李白"
       
//二维数组arr:
    let Hore1 = arr[0][0];
       console.log(Hore1);//"李白"

使用解构:

javascript 复制代码
 // 一维数组
       let [Hore,,,] = arr;
       console.log(Hore);//"李白"

// 二维数组
    let [[Hore1,],,] = arr1;
    console.log(Hore1);//"李白"

使用扩展运算符:

javascript 复制代码
//一维数组
let [Hore, ...Hores] = arr;
    console.log(Hore, Hores);//"李白"   ["韩信", "诸葛亮"]
//二维数组
let [[Hore1,...Hores1],...Hores2]= arr1
    console.log(Hore1, Hores1, Hores2);//李白 ["韩信"] ["诸葛亮"]

但是扩展运算符只能使用在后面

解构的时候给变量设置默认值,数组的解构设置默认值会很少,对象会多一点

javascript 复制代码
let arr2 = [];
    let [list = "默认值"] = arr2;
    console.log(list);//"默认值"

2.对象的解构:

对象的解构是没有顺序的,只需要在左右放上相同的key值,就能提取到

javascript 复制代码
let person = {
        name: "wql",
        age: undefined
    }

    let { name1,age1 } = person;
    console.log(name1,age1);//"wql"  undefined

给解构的对象变量设置默认值:

javascript 复制代码
let { age = 22 } = person;
    console.log(age);//22

为提取的变量取一个别名 n:

javascript 复制代码
let { name: n } = person;
    console.log(n);//wql

复杂的对象解构:

javascript 复制代码
let obj = {
        p: [
            'Hello',
            { str: "world!" }
        ]
    }

    let { p: [, { str }] } = obj;
    console.log(str)//world

3.字符串解构:

解构输出q

javascript 复制代码
let str1 = "wql"; 4
    let [, s ,] = str1;
    console.log(s);//q

函数参数的解构: 数组作为参数 使用较少

javascript 复制代码
 function add([a, b]) {
        return a + b;
    }

    let arr3 = [1, 2];
    console.log(add([1, 2]));//3

//对象作为参数

javascript 复制代码
function sayName({name,age}){
        console.log(`我叫${name},我今年${age}岁了!`);
    }

    let person1 = {
        name:"小明",
        age:22
    }

    sayName(person1);//我叫小明,我今年22岁了!

4.其它用途:

交换数据:

例子 一:

javascript 复制代码
   let x = 1;
   let y = 2;

   [x,y] = [y,x]
   console.log("x:"+x,"y:"+y);//x:2 y:1

例子二:

javascript 复制代码
function controls(){
       function a(){
            console.log("a");
           
       }
       function b(){
        	console.log("b");
       }

       return{
           a:a,
           b:b
       }
   }

   let {a} = controls();
   a();//a
相关推荐
kandee8 分钟前
vscode混淆js文件的插件用法(jshaman)
javascript·ide·vscode
谢尔登37 分钟前
a 标签的跳转机制
前端·javascript·webpack·node.js
毕设源码-邱学长1 小时前
【开题答辩全过程】以 基于Vue的爱心公益募捐平台的设计与实现为例,包含答辩的问题和答案
前端·javascript·vue.js
前端小白在前进1 小时前
力扣刷题:千位分割数
javascript·算法·leetcode
Hilaku2 小时前
那个把代码写得亲妈都不认的同事,最后被劝退了🤷‍♂️
前端·javascript·代码规范
Dragon Wu2 小时前
TanStack Query(React Query) 常用api及操作总结
前端·javascript·前端框架
喵个咪2 小时前
开箱即用的 GoWind Admin|风行,企业级前后端一体中后台框架:用 JavaScript/Lua 解锁动态业务扩展能力
javascript·go·lua
BD_Marathon2 小时前
Vue3_插值表达式
javascript
前端达人2 小时前
原生JavaScript vs 前端框架,2026年该怎么选?
开发语言·前端·javascript·前端框架·ecmascript
AAA阿giao2 小时前
JavaScript 中 this 的终极解析:从 call、bind 到箭头函数的深度探索
前端·javascript·ecmascript 6