博客列表 >前端开发-对象与数组的解构赋值20221103

前端开发-对象与数组的解构赋值20221103

P粉114035831
P粉114035831原创
2022年11月16日 19:52:11362浏览

对象与数组的解构赋值

* 1.数组

建变量数组

let [uname,email]=[‘老王’,’asd@qq.com’]
console.log(uname,email)
//更新
//在[],{},()之前的分号不能省略
;[uname,email] = [‘老张’,’qwe@qq.com’]
console.log(uname,email)
console.log(‘———————‘)

A.值数量 < 变量数量,默认值

//无法识别出 “gender”需要对其赋值
;[uname,email,gender] = [‘小芳’,’zxc@qq.com’]
console.log(uname,email,gender)
//对”gender”赋值’女’后就能被打印
;[uname,email,gender=’女’] = [‘小芳’,’zxc@qq.com’]
console.log(uname,email,gender)

B.值数量>变量数量,则需要使用…rest

;[uname,…arr] = [‘小芳’,’zxc@qq.com’,’女’]
//打印出一个数值和(把数组后面二个字符口串放到一个数组显示)数组
console.log(uname, arr)
//打印出数值,都展开显示
console.log(uname,…arr)
console.log(‘————————-‘)

//应用场景:交接二个数
//建二个变量以方便交换
let x = 10
let y = 30
//交换方式
;[y,x] = [x, y]
//使用反式符
console.log(x=${x},y=${y})
console.log(‘———————-‘)

* 2.对象解构

变量名 === 属性名

//创建变量
let {num, price} = {num:1, price:2000}
console.log(num,price)
//更新.{}不能出现在等号左边(左值),所以加上括号()转成表达式
;({num,price} = {num:2, price:3000})
console.log(num, price)

//命名与前面的冲突,则需要另起一个别名
let { pname, price:block} = { pname:’电脑’, price:3000}
//访问时要用别名
console.log(pname, block)
console.log(‘———————————-‘)

应用场景1: 克隆对象

let lesson = { name: ‘text’, score:11 }
console.log(lesson)
//如果想创建二个不相关的对象,值又完全一样,只能克隆
let {…obj} = lesson
console.log(obj)
// obj不等于lesson
console.log(obj === lesson)
console.log(‘———————————-‘)

应用场景2:解构传参

let show = ({uname, email})=> {return ${uname},${email}}

user= {uname:’老王’, email:’qwe@qq.com’}
console.log(show(user))

* 访问器属性

let course = {
lesson:{
name:’老王’,
score:60,
},

getScore (){
return {
name:this.lesson.name,
course:this.lesson.score,
}
},

setScore(score)
{this.lesson.score = score
}
}

console.log(course.lesson.score)

普通方法 ===> 访问器属性

getScore ===> get score

使属性方法化

course = {
lesson:{
name:’老王’,
score:60,
},
get score (){
return {
name:this.lesson.name,
course:this.lesson.score,
}
},

  1. set score(score)
  2. {this.lesson.score = score
  3. }
  4. }

console.log(course.score)

访问器属性方法化后,简化了代码

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议