什么是解构?

什么是解构?

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

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

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
相关推荐
Hello--_--World7 分钟前
ES13:类私有属性和方法、顶层 await、at() 方法、Object.hasOwnProperty()、类静态块 相关知识点
开发语言·javascript·es13
comerzhang65528 分钟前
Web 性能的架构边界:跨线程信令通道的确定性分析
javascript·webassembly
zhensherlock1 小时前
Protocol Launcher 系列:Overcast 一键订阅播客
前端·javascript·typescript·node.js·自动化·github·js
px不是xp3 小时前
DeepSeek API集成:让小程序拥有AI大脑
javascript·人工智能·小程序
小汪说干货3 小时前
2026年4月最新|公众号文章插入文档附件3种技术方案
javascript·小程序
qq_12084093714 小时前
Three.js 骨骼动画工程实战:AnimationMixer、剪辑与混合权重调参
开发语言·javascript·ecmascript
早起傻一天~G5 小时前
vue2+element-UI上传图片封装
开发语言·javascript·ui
广师大-Wzx5 小时前
JavaWeb:前端部分
java·前端·javascript·css·vue.js·前端框架·html
M ? A5 小时前
你的 Vue v-memo 与 v-once,VuReact 会编译成什么样的 React 代码?
前端·javascript·vue.js·经验分享·react.js·面试·vureact
zopple6 小时前
前端三剑客 vs Vue.js:核心区别解析
前端·javascript·vue.js