ES6系列文章 Destructuring

发布时间:2019-08-09 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了ES6系列文章 Destructuring脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

Destructuring解构是ES6很重要的一个部分。和箭头函数letconst 同等地位,解构可能是你日常用到最多的语法之一了。解构是什么意思呢?它是js 表达式,允许我们从数组、对象、map、set 中抽取数据同时为多个变量赋值。

@H_406_9@解构入门

首先让我们初步了解下解构解决哪些问题。你可能从后台得到 PErson 的数据如下:

const person = {
    First: 'xi',
    last: 'xi',
    country: 'china',
    cITy: 'beijing'
};
// 需要单独获得 first和 last 的值
const first = person.first;
const last = person.last;

想从 person 对象中获取到数据不得不写大量重复的代码。此时解构的价值就体现出来了。解构代码如下:

const { first, last } = person;

上面的代码表示声明两个变量 first last,然后 first = person.first, last = person.last。如果你还行获取 person的 city,只需进行如下操作:

const { first, last, city } = person;

以上: 解构可以减少重复的代码

解构之重命名

有时后台返回的命名比较狗血,你不喜欢或者变量名在该作用域中已经被占用了。例如:

const country = 'USA';
const person = {
    first: 'xi',
    last: 'xi',
    country: 'china',
    city: 'beijing'
};
const {first, last, country?} = person;

此时你仍想获取 person 中的 coutry 数据怎么办呢?为此解构重命名功能就闪亮登场。

// personCountry is whart you needs
const {first, last, country: personCountry} = person;

解构之设置默认值

ES6为我们提供了设置默认值的语法。解构也一样。下面大家思考一下,在对一个 object 进行解构时,若对应的对象属性不存在那会怎样呢?

const rect = {
    width: 150
}
const { height, width } = rect;
console.LOG(height);//undefined

运行代码我们看到 height === undefined。实际业务中长方形的 height 是不能没有值的。为了增强程序的健壮性,我们经常会给 height 一个默认值。height || 150。下面介绍解构设置默认值的语法

const rect = {
    width: 150
}
const { height = 150, width = 300 } = rect;
console.log(height, width);//150, 150

?在解构设置默认值的语法中, 我们要特别注意只有当 value 的值严格等于 undefined 时,默认值才会生效null, false, 0都算正常值的范畴。

解构进阶

解构时同时使用重命名和设置默认值的语法。直接上代码:

const person = { first: 'xi', last: 'yuanyuan' };
const { middle: middleName = 'xixi' } = person;
console.log(middleName); // 'xixi'

若可以理解上面的代码,那你的 es6水平已经很好了。下面对上述语句做简单说明:

  1. 首先我们声明了一个变量middleName
  2. 其次我们查询 person的 middle 属性,看其是否有值。若有,middleName = person.middle
  3. 若 person 没有 middle 属性, 那么将middleName赋值为'xixi'。

refs

JavaScript’s Destructuring

欢迎访问个人博客 ?xixi小站?

脚本宝典总结

以上是脚本宝典为你收集整理的ES6系列文章 Destructuring全部内容,希望文章能够帮你解决ES6系列文章 Destructuring所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。