前端基础知识-ES6解构赋值(将数组内元素、字符串内字符、对象内属性值快速赋值给其他变量)

前言:

将数组、字符串、对象进行展开,并将展开的数据赋值给指定变量,以达到语法简化的目的,日常开发中可以大大提升我们的效率。

主要语法:

一、[变量1,变量2。。。]=目标数组

将数组里面的内容赋给其他变量

场景1:
javascript 复制代码
      let arr = ["1", "2", "3"];
      let [a, b, c] = arr;
      console.log(a, b, c);

控制台输出:

场景2:

将数组内部分值赋值给其他变量

javascript 复制代码
      let arr = ["1", "2", "3"];
      let [, , c] = arr;
      console.log(c);

控制台输出:

场景3:

与扩展运算符搭配使用,赋值指定变量,将余下的元素赋值指定数组

javascript 复制代码
      let arr = ["1", "2", "3"];
      let [a, ...demo] = arr;
      console.log(a, demo);

控制台输出:

二、[变量1,变量2。。。]=目标字符串

场景1:

赋值全部字符串

javascript 复制代码
      let str = "1234567";
      let[a,b,c,d,e,f,g]=str;
      console.log(a,b,c,d,e,f,g);

控制台输出:

场景2:

赋值部分字符

javascript 复制代码
      let str = "1234567";
      let [a, b, c] = str;
      console.log(a, b, c);
      let [, , , , , , g] = str;
      console.log(g);

控制台输出:

场景3:

与扩展运算符搭配使用,赋值指定变量,将余下的字符赋值指定数组

javascript 复制代码
      let str = "1234567";
      let [a, ...demo] = str;
      console.log(a, demo);

控制台输出:

三、{变量1,变量2}=目标对象

场景1:

赋值全部属性值

javascript 复制代码
      let obj = {
        id: 1,
        name: "admin",
        age: 22,
      };
      let { name, id, age } = obj;
      console.log(name, id, age);

控制台输出:

场景2:

赋值部分属性值

javascript 复制代码
      let obj = {
        id: 1,
        name: "admin",
        age: 22,
      };
      let { name, age } = obj;
      console.log(name, age);
      let { id } = obj;
      console.log(id);

控制台输出:

四、 {属性名称1:变量名称1}=目标对象

场景1:

赋值部分属性

javascript 复制代码
      let obj = {
        id: 1,
        name: "admin",
        age: 22,
      };
      let { name: sname } = obj;
      console.log(sname);
相关推荐
华玥作者11 小时前
[特殊字符] VitePress 对接 Algolia AI 问答(DocSearch + AI Search)完整实战(下)
前端·人工智能·ai
Mr Xu_11 小时前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠11 小时前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
sleeppingfrog11 小时前
zebra通过zpl语言实现中文打印(二)
javascript
lang2015092811 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
好家伙VCC12 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
未来之窗软件服务13 小时前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君
baidu_2474386113 小时前
Android ViewModel定时任务
android·开发语言·javascript
嘿起屁儿整13 小时前
面试点(网络层面)
前端·网络
VT.馒头13 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript