当前位置:网站首页>ES6----解构赋值
ES6----解构赋值
2022-07-28 05:19:00 【哈哈ha~】
1.概述
解构赋值是对赋值运算符的扩展,是声明变量的高级写法
针对数组或者对象进行模式匹配,然后对其中的变量进行赋值
在代码书写上简洁且易读,语义更加清晰明了;也方便了复杂对象中数据字段获取
2.解构模型
解构的源:解构赋值表达式的右边部分。
解构的目标:解构赋值表达式的左边部分。
3.解构的语法
- 变量修饰符 数据模型=数据源
(一)数组模型的解构(Array)
基本
let [a, b, c] = [1, 2, 3];
console.log(a, b, c); //1 2 3var arr=[100,200]
var [a,b]=arr
//隐式代码: var a=arr[0]
// var b=arr[1] var [name,{age}]=arr
//隐式代码:var name=arr[0]
// var age=arr[1].age function useState(num){
return []
}
var [count,setCount]=useState(0)
//隐式代码:var count=[][0]
// var setCount=[][1]function useState(num){
function fn(){}
return [num,fn]
}
var [count,setCount]=useState(10)
console.log(count)//10
setCount(2000)
console.log(count)//2000//形参使用解构赋值
function fn({x,y}){
console.log(x)
console.log(y)
}
var obj={x:100,y:200}
fn(obj) function fn(){
return [100,function(arg){}]
}
let [ped,setpwd]=fn()
setpwd(pwd)可嵌套
let [a, [[b], c]] = [1, [[2], 3]];
console.log(a, b, c); //1 2 3 let [a,{son:[{age,s2:{son:[x1,y1]}]}]=obj
//隐式代码
// let y1=obj[1].son[0].s2.son[1]可忽略
let [a, , b] = [1, 2, 3];
console.log(a, b); //1 3不完全解构
let [a = 1, b] = []; // a = 1, b = undefined剩余运算符
let [a, ...b] = [1, 2, 3];
console.log(a, b); //a = 1, b = [2,3]字符串
//在数组的解构中,解构的目标若为可遍历对象,皆可进行解构赋值。可遍历对象即实现 Iterator 接口的数据
let [a, b, c, d, e] = 'hello';
console.log(a, b, c, d, e); //h e l l o解构默认值
//解构有默认值 不传参就=20
let obj={}
let {a=20}=obj
console.log(a)let [a = 2] = [undefined]; // a = 2
当解构模式有匹配结果,且匹配结果是 undefined 时,会触发默认值作为返回结果。
let [a = 3, b = a] = []; // a = 3, b = 3
let [a = 3, b = a] = [1]; // a = 1, b = 1
let [a = 3, b = a] = [1, 2]; // a = 1, b = 2
1. a 与 b 匹配结果为 undefined ,触发默认值:a = 3; b = a =3
2. a 正常解构赋值,匹配结果:a = 1,b 匹配结果 undefined ,触发默认值:b = a =1
3. a 与 b 正常解构赋值,匹配结果:a = 1,b = 2(二)对象模型的结构(Object)
- 基本
var obj={aeg:21,name:"lili"}
var {age,name}=obj
//隐式代码: var age=obj.age
// var name=obj.name
console.log(age)
console.log(name)var {x1,x2}=obj2
//隐式代码 var x1=obj.x1
// var x2=obj.x2
var {x1:{x2},x3}=obj3
//隐式代码var x1=obj3.x1
// var x2=obj3.x1.x2 //当obj3={} 时 这一行会报错 x1为undefined 不能.x2操作
// var x3=obj.x3可嵌套可忽略
let obj = {p: ['hello', {y: 'world'}] };
let {p: [x, { y }] } = obj;
// x = 'hello'
// y = 'world'
let obj = {p: ['hello', {y: 'world'}] };
let {p: [x, { }] } = obj;
// x = 'hello'不完全解构
let obj = {p: [{y: 'world'}] };
let {p: [{ y }, x ] } = obj;
// x = undefined
// y = 'world'剩余运算符
let {a, b, ...rest} = {a: 10, b: 20, c: 30, d: 40};
// a = 10
// b = 20
// rest = {c: 30, d: 40}解构默认值
let {a = 10, b = 5} = {a: 3};
// a = 3; b = 5;
let {a: aa = 10, b: bb = 5} = {a: 3};
// aa = 3; bb = 5;边栏推荐
- c语言:通过一个例子来认识函数栈帧的创建和销毁讲解
- Export excel, generate multiple sheet pages, and name them
- visio如何精确控制图形的大小和位置及角度
- 对极大似然估计、梯度下降、线性回归、逻辑回归的理解
- 冶金物理化学复习 --- 气-液相反应动力学
- 树莓派WIFI一键连接配置
- Openjudge: stone scissors cloth
- MySQL uses list as a parameter to query
- When using \hl for highlighting, latex always reports an error when encountering a reference, showing that there are fewer or more parentheses
- Openjudge: patient queuing
猜你喜欢

顺序表oj之删除特定的元素

Review of metallurgical physical chemistry -- rate equations of complex reactions

环形链表问题

Canvas绘图1

BigDecimal rounds and retains two decimal places

冶金物理化学复习 -- 金属电沉积过程中的阴极极化,超电势以及阳极和阳极过程

顺序表的增删查改

Using Navicat or PLSQL to export CSV format, more than 15 digits will become 000 (e+19) later

冶金物理化学复习 --- 冶金反应动力学基础与多相反应动力学特征

A file upload tool website written by individuals
随机推荐
【博学谷学习记录】超强总结,用心分享 | 集合
Custom JSON return data
IO流的使用
环形链表问题
冶金物理化学复习 --- 金属的电沉积,还原过程
Idea configures the service (run dashboard) service, and multiple modules are started at the same time
顺序表的增删查改
softmax多分类 梯度推导
es6新增数据类型--->Symbol、Map、Set
Pytorch uses hook to get feature map
Openjudge: maximum span of string
pytorch安装----CPU版的
动态卷积的本质
C语言回顾(可变参数篇)
标准C语言学习总结6
记录某某小卢的第一篇文章
openjudge:字符串最大跨距
Review of metallurgical physical chemistry -- Fundamentals of chemical reaction kinetics
Oracle create table, delete table, modify table (add field, modify field, delete field) statement summary
MySQL uses list as a parameter to query