美文网首页
3.解构赋值

3.解构赋值

作者: summer_1874 | 来源:发表于2018-03-06 11:22 被阅读0次

解构的分类

  1. 对象解构

  2. 数组解构

  3. 混合解构

  4. 解构参数

对象解构

const obj = {
  str,
  arr:[1,2]
}

const {str = 'power',arr} = obj;
//解构可传默认值
console.log(str,arr); //power,[1,2]

解构赋值

let business = {
  a:1,
  b:2
},
a = 3,
b = 3;
//解构赋值
({a,b} = business);
console.log(a,b);//1,2

嵌套对象解构

let obj = {
  a:{
    b:{
      c:{
        d:5
      }
    }
  }
};
const {a:{b:{c:{d}}}} = obj;
console.log(d);//5

数组解构

数组解构

选择性的解构元素,不需要解构的元素就使用逗号代替(,)。不需要像对象解构一样使用key属性。

let arr = [1,2,3]
const [a,b,c] = arr
console.log(a,b,c)//1,2,3

let arr2 = [1,2,3]
const [,d] = arr2
console.log(d)//3

解构赋值

如果你没有看明白上面说到的对象解构赋值的含义,那么看完下面的数组解构赋值,或许你会有比较清晰的理解。

这个例子中,正常情况下打印a的值是haha,但是将数组arr的第一个元素解构赋值给a,a的值就变成了1。

//初始化一个变量a
let a = "therefore";
//定义一个数组
let arr = [1, 2, 3];
//解构赋值a,将arr数组的第一个元素解构赋值给a,
[a] = arr;
console.log(a); // 1

使用解构赋值,还可以调换2个变量的值。

let a = 1, b = 2;
[a, b] = [b, a];
console.log(a, b); // 2 1

嵌套数组解构

let arr = [1,[11,22,33],2,3]
const [a,[b,c,d]] = arr
console.log(a,b,c,d);//1,11,22,33


//同于
"use strict";

var arr = [1, [11, 22, 33], 2, 3];
var a = arr[0],
    _arr$ = arr[1],
    b = _arr$[0],
    c = _arr$[1],
    d = _arr$[2];

console.log(a, b, c, d);//1,11,22,33
//so easy

不定元素解构

//使用扩展运算符解构赋值
let arr = [1,2,3,4]
const [...a] = arr
console.log(a);//[1,2,3,4]这种做法就是克隆arr数组

混合解构

let obj = {
  a:{
    aa:1
  },
  b:[2,3]
}
const {
  a:{aa},
  b:[...arr]
} = obj
console.log(aa,b)//1,[2,3]

解构参数

当给函数传递参数时,我们可以对每个参数进行解构,我给option的参数设置了默认值,这样可以防止没有给option传参导致的报错情况。

function Ajax(url, options) {
  const {timeout = 0, jsonp = true} = options
  console.log(url, timeout, jsonp)
};
Ajax('baidu.com', {
  timeout: 1000,
  jsonp: false
}) // "baidu.com" 1000 false

总结

本章讲解了对象解构赋值和数组解构赋值,以及对象和数组混合情况下的解构赋值操作,最后一个知识点是解构函数的参数。每一个都是重点,特别是最后一个,解构参数恐怕你经常在用了,只是通常你没发现。

相关文章

  • ES6 变量的解构赋值

    1.数组的解构赋值 2.对象的解构赋值 3.字符串的解构赋值 4.数值和布尔值的解构赋值 5.函数参数的解构赋值 ...

  • 第三章 变量的解构赋值

    1.数组的解构赋值2.对象的解构赋值3.字符串的解构赋值4.数值和布尔值的解构赋值5.函数参数的解构赋值6.圆括号...

  • JS基础:ES6关于基本语法的一些扩展

    目录一. 解构赋值 1. 数组的解构赋值 2. JS对象的解构赋值 3. 解构赋值的应用场景二. 字符串的扩展 1...

  • 3.解构赋值

    解构的分类 对象解构 数组解构 混合解构 解构参数 对象解构 解构赋值 嵌套对象解构 数组解构 数组解构 选择性的...

  • 3. 解构赋值

    阮一峰-变量的解构赋值 大神写得算是相当的友好了. 我感觉基本都不用写笔记了. 把不会的大概记一下. 数组的解构n...

  • ES6 2.解构赋值

    解构赋值 解构赋值的分类 数组解构赋值 对象解构赋值 字符串解构赋值 布尔值解构赋值 函数参数解构赋值 数值解构赋...

  • ES6 语法(解构赋值)

    什么是解构赋值及用法 解构赋值分类:数组解构赋值对象解构赋值字符串解构赋值布尔值解构赋值函数参数解构赋值数值解构赋...

  • 解构赋值

    解构赋值: 分解一个对象的结构 1.数组 2.复杂嵌套 3.对象解构的变量名 4.默认解构赋值 5.省略解构

  • ES6解构赋值、交换两个变量的值、设置函数默认值、模板字符串、箭

    1,解构赋值 解构赋值主要包括数组的解构赋值、对象的解构赋值、字符串的解构赋值、函数参数的解构赋值。 (1)数组的...

  • 解构赋值,设置函数默认值,箭头函数

    1,解构赋值 解构赋值主要包括数组的解构赋值、对象的解构赋值、字符串的解构赋值、函数参数的解构赋值。 (1)数组的...

网友评论

      本文标题:3.解构赋值

      本文链接:https://www.haomeiwen.com/subject/kglhfftx.html