Blogger Information
Blog 28
fans 0
comment 0
visits 13137
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
对象与数组的解构赋值以及访问器属性与普通属性的区别与联
手机用户1594223549
Original
316 people have browsed it

一.对象与数组的解构赋值

1.输出结果

2.代码部分

  1. // ! 对象与数组的解构赋值
  2. // 结构语法
  3. // * 模板 = 集合(数组,对象)
  4. // ? 1.数组结构
  5. let [nname, wage] = ['张三', '15000']
  6. console.log(nname, wage)
  7. // 更新
  8. // 在 [],{},()之前的分号不能省略
  9. ;[nname, wage] = ['李四', '20000']
  10. console.log(nname, wage)
  11. console.log('---------------')
  12. // 1. 值数量 < 变量数量, 默认值
  13. ;[mname, wage, gender = '男'] = ['王五', '15000']
  14. console.log(nname, wage, gender)
  15. // 2. 值数量 > 变量数量, ...rest
  16. ;[nname, ...arr] = ['马六', '20000', '男']
  17. console.log(nname, arr)
  18. console.log(nname, ...arr)
  19. console.log('--------------')
  20. // ? 1.对象结构
  21. // 变量名 === 属性名
  22. // 左边是模版,右边是对象
  23. let { age1, wage1 } = { age1: 24, wage1: 9000}
  24. console.log(age1, wage1)
  25. // [],{},()之前分号不能省略
  26. // 命名冲突: 别名
  27. // {}不能出现在等号左边(左值),所以加上括号()转成表达式
  28. ;({ age2, wage2 } = { age2: 30, wage2: 10000 })
  29. console.log(age2, wage2)
  30. console.log('-----------------')
  31. // ! (1) 结构传参
  32. let open = function (id) {
  33. // id 是一个对象
  34. // 格式化打印传参数
  35. return `${id.nname}: ( ${id.wage3} )`
  36. }
  37. let id = {nname: '王强', wage3: 5000}
  38. // 调用
  39. console.log(open(id))
  40. // * 使用对象解构进行简化传参
  41. open = function ({ nname, wage3 }) {
  42. // user 是一个对象
  43. return `${nname}: ( ${wage3} )`
  44. }
  45. id = { nname: '黄六', wage3: 30000 }
  46. console.log(open(id))

二.访问器属性,和普通属性之间的区别与联系

1.输出结果

2.代码部分

  1. // ! 访问器属性,和普通属性之间的区别与联系
  2. // ? 使用"访问器属性"
  3. wage = {
  4. line: {
  5. name: 'darren',
  6. money: 10000,
  7. },
  8. money: 20000,
  9. // getMoney===> get money
  10. // 普通方法 ===> 访问器属性
  11. // 如果使用访问器属性, get必须要有, set 可选
  12. get money () {
  13. return {
  14. name: this.line.name,
  15. money: this.line.money,
  16. }
  17. },
  18. // 将一个方法,伪装成"属性"
  19. set money(money) {
  20. if (money >= 3000 && money <= 30000) {
  21. // 把外部的数据读取过来
  22. this.line.money = money
  23. } else {
  24. console.log('工资必须在3000-10000之间')
  25. }
  26. },
  27. }
  28. // 经过包装和伪造, 现在就可以像访问属性一个访问一个方法了
  29. // wage.money === wage.get money()
  30. console.log(wage.money)
  31. wage.money = 2000
Correcting teacher:PHPzPHPz

Correction status:qualified

Teacher's comments:完成的很好
Statement of this Website
The copyright of this blog article belongs to the blogger. Please specify the address when reprinting! If there is any infringement or violation of the law, please contact admin@php.cn Report processing!
All comments Speak rationally on civilized internet, please comply with News Comment Service Agreement
0 comments
Author's latest blog post