Skip to content

before

本篇主要介绍js的内建的对象,学习其具体的属性和方法。

这里提前说一个概念,那就是:

  • 破坏性方法,即对原数据进行操作,比如原地排序、反转数组。
  • 非破坏性方法,不会影响原数据,而是经过一番如此这般之后,返回新的结果,比如两个字符串通过拼接方法进行拼接,会得到一个新的字符串,而不影响原来的两个字符串。

Array

https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array

你可以把JavaScript中的数组(Array)当成Python中的列表。

什么是序列?

所谓序列,指的是一块可存放多个值的连续内存空间,这些值按一定顺序排列,可通过每个值所在位置的编号(称为索引)访问它们。

为了更形象的认识序列,可以将它看做是一家旅店,那么店中的每个房间就如同序列存储数据的一个个内存空间,每个房间所特有的房间号就相当于索引值。也就是说,通过房间号(索引)我们可以找到这家旅店(序列)中的每个房间(内存空间)。

序列中的每个元素都有一个序号,即元素的位置,也叫做索引、索引下标、下标索引,序列中的第一个元素索引为0,第二个索引为1,依此类推。 注意:JavaScript中序列编号机制是从0开始的,其他大部分的语言都是如此设计。另外,这里的序列如无特指,一律为有序序列。

Array也属于序列类型,它具有以上序列的特点。且,Array中可以存储JavaScript中的任意数据类型;如果数组中嵌套的还是数组,可以称为二维数组,如果嵌套更多层,可以称为多维数组,不过处理起来麻烦了,通常不这么干。

另外,虽然数组能存任意类型,但建议存储为同一类型的数据,便于处理。

最后,数组的长度没有限制。

基础操作

创建数组

javascript
// 通过new来声明一个空的数组
// let a = new Array();

// 也可以省略new,如下面两种简写方式,跟new Array()效果一样
// let a = Array();
let a = [];
// let a = ['a', 'b', 'c']; // 也可以有初始的元素

console.log(a, typeof a); // [] object
console.log(a instanceof Array); // true

添加/更新

javascript
let a = [];

// 通过索引添加或者更新元素
a[0] = 10; // 此时数组的0索引对应的位置没有数据,所以这个操作是添加元素
a[0] = 20; // 0索引在上一步已经赋值了,所以这里是更新

console.log(a[0]); // 通过索引取值
console.log(a[10]); // 数组中没有下标为10的索引,所以返回undefined
console.log(a.length); // 返回数组的元素的个数,即返回数组的长度

非连续性数组

javascript
let a = [];

a[0] = 10;
a[1] = 20;
a[2] = 30;
a[7] = 50;
a[5] = 70;

console.log(a); // [ 10, 20, 30, <2 empty items>, 70, <1 empty item>, 50 ]
console.log(a.length); // 8

// 借助length的特点,我们可以为数组追加元素
a[a.length] = 80;
console.log(a); // [ 10, 20, 30, <2 empty items>, 70, <1 empty item>, 50, 80 ]

// length的值可以修改
// length值改小
a.length = 2; // 从右到左进行删除,保留两个元素
console.log(a); // [ 10, 20 ]

// length值改大
a.length = 10; // 会将后续的下标值置为空
console.log(a); // [ 10, 20, <8 empty items> ]

如上例,如果不看打印结果,我们自数数的话,这个数组中元素的个书应该是5个,但a.length结果确是8个?????

什么情况?这就要说一点,length的返回值取决于数组中索引下标最大的值加1,上例中最大的索引是7,加1后的结果是8,然后返回了...

那么这种情况和这样的数组都是不合理的,也不符合逻辑的。所以这种数组被称为非连续性数组,数组中非连续部分默认填充一个empty,表示这个索引位置的元素是空的。

在开发中,我们应该避免使用非连续性数组。

遍历数组

javascript
let a = ['a', 'b', 'c'];

// for循环遍历数组,正序
for (let i = 0; i < a.length; i++) {
    console.log(i, a[i]);
}
// 倒叙遍历
for (let i = a.length - 1; i >= 0; i--) {
    console.log(i, a[i]);
}

// for in 遍历,只能正序遍历
for (let i in a) {
    console.log(i, a[i]);
}

// 新语法,拿到的直接就是元素,但兼容性有待加强
for (let i of a) {
    console.log(i);
}

// 使用array的forEach,函数中的第一个参数是元素,第二个参数是索引,第三个参数就是被遍历的数组,用的不多
a.forEach(function (item, index, arr) {
    console.log(index, item, arr);
});

最常用的就是最开始的for循环或forEach方法去遍历数组,比较灵活。

常用方法

添加和删除:push/pop/unshift/shift

javascript
let a = ['a', 'b', 'c'];

// 追加一个或多个元素,push再追加后,还会返回数组新的长度
// let res = a.push('d');
// a.push('x', 'y');
// console.log(a, res); // [ 'a', 'b', 'c', 'd', 'x', 'y' ] 4

// 从数组尾部删除元素,没有参数,一次只能删除一个元素,且将删除的元素返回
// let res = a.pop();
// console.log(a, res); // [ 'a', 'b' ] c


// 从数组头部插入一个或多个元素,并将数组的新的长度返回
// a.unshift('d');
// let res = a.unshift('x', 'y');
// console.log(a, res); // [ 'x', 'y', 'd', 'a', 'b', 'c' ] 6

// 删除数组头部元素,并将其返回
// let res = a.shift();
// console.log(a, res); // [ 'b', 'c' ] a

练习:

javascript
function Person(name, age) {
    this.name = name;
    this.age = age;
}

let p1 = new Person('沙和尚', 28);
let p2 = new Person('红孩儿', 10);
let p3 = new Person('猪八戒', 30);
let p4 = new Person('孙悟空', 16);

arr = [p1, p2, p3, p4];

// 请定义一个函数,并将成年人和未成年人分别存储(数组、对象都可以)
function func(arr) {
    let res = {"未成年": [], "成年人": []};
    for (let i = 0; i < arr.length; i++) {
        if (arr[i].age >= 18) {
            a['成年人'].push(arr[i]);
        } else {
            a['未成年'].push(arr[i]);
        }
    }
    return res;
}

res = func(arr);
console.log(res);

判断数组元素是否存在:indexOf/includes

首先,判断指定元素是否存在,不能用in,因为js中,用in判断数组是判断索引位置是否存在的:

javascript
let a = ['a', 'b', 'c'];
console.log('a' in a); // false
// 索引1~2都是合法的,不在这范围之内都返回false
console.log(1 in a); // true
console.log(2 in a); // true
console.log(3 in a); // false
console.log(30 in a); // false

indexOf/lastIndexOf

javascript
// 判断指定元素在不在数组中
let a = ['a', 'b', 'c'];
// indexOf,从左到右找元素
// 第一个参数:要查找的元素
// 第二个参数: 不传参,即默认从0索引开始往右找,找到第一个返回其索引下标;你也可以指定从哪个索引开始找
// 找不到的话,返回 -1
console.log(a.indexOf('a')); // 0
// 从索引1开始往右找 "w"
console.log(a.indexOf('w', 1)); // -1


/*
lastIndexOf,从右到左找元素
第一个参数:要查找的元素
第二个参数: 不传参,即默认从最后索引开始往左找,找到第一个返回其索引下标
	如果传值,即表示从指定索引开始往左找,找到第一个返回其索引下标
找不到的话,返回 -1
*/
let arr = ['a', 'b', 'a', 'b', 'e', 'e', 'b'];
// 从右开始往左找第一个,返回索引下标
console.log(arr.lastIndexOf('b')); // 6
// 从索引2开始往左找第一个出现的元素,返回其索引下标
console.log(arr.lastIndexOf('b', 2)); // 1

includes

javascript
let a = ['a', 'b', 'c'];
// includes如果在,返回true,否则返回false
console.log(a.includes('a'));
console.log(a.includes('w'));

拼接数组:join

join以指定符号将数组的元素拼接为字符串:

javascript
let arr = ['a', 'b', 'a', 'b', 'e', 'e', 'b'];
// 默认以逗号分割
console.log(arr.join()); // a,b,a,b,e,e,b
// 可以指定连接符号
console.log(arr.join('.')); // a.b.a.b.e.e.b
console.log(arr.join('-')); // a-b-a-b-e-e-b
console.log(arr.join('')); // ababeeb

反转:reverse

破坏性方法!reverse方法在原地对数组进行反转:

javascript
let arr = ['a', 'b', 'c', 'd'];
arr.reverse();
console.log(arr); // [ 'd', 'c', 'b', 'a' ]

数组排序:sort

破坏性方法!sort对数组进行排序:

javascript
let arr = ['c', 'd', 'a', 'b'];
// 默认升序排序
arr.sort(); // [ 'a', 'b', 'c', 'd' ]
// 想要降序排序的话,还是使用reverse吧
// arr.reverse();

使用sort对数组内的元素全是字符进行排序没有问题,因为它比较的字符在ASCII码表上的位置进行比较的,但要命的是,对于数字它也是按照这个规则来的:

javascript
let arr = [5, 3, 1, 2, 10, 18, 60];
// arr.sort(); // [ 1, 10, 18, 2, 3,  5, 60 ]
// 将数字转为字符串,然后按照ASCII码表进行排序,很明显不符合我们的需要
// 所以我们要自定义排序规则,而且规则非常简单固定
arr.sort(function (a, b) {
    // 想要升序就a - b
    // return a - b; // [ 1,  2,  3, 5, 10, 18, 60 ]
    // 想要降序就b - a
    return b - a; // [ 60, 18, 10, 5, 3,  2,  1 ]
});
console.log(arr);

对于数字类型的排序算法,内部使用的是什么算法,不同的浏览器有不同的实现。

切片和替换:slice/splice

slice用来对数组进行切片(截取),参数:

  1. 截取的起始位置(包含起始位置)。
  2. 截取的结束位置索引(不包含结束位置),如果截取结束位置不传参,表示从起始位置截取到数组的最后。

slice切片时,不会影响到原数组,而是将截取的结果以新的数组返回,所以该方法可以称为非破坏性方法。

javascript
let a = ['a', 'b', 'c', 'd'];
console.log(a.slice(1, 3)); // [ 'b', 'c' ]
console.log(a.slice(1)); // [ 'b', 'c', 'd' ]

// 索引可以传负值,-1表示数组倒数第一个元素下标;-2表示倒数第二个......
console.log(a.slice(1, -2)); // [ 'b' ]

splice可以用来删除、替换、添加数组中的元素,它是个破坏性方法,即它影响到原数组。

javascript
let a = ['a', 'b', 'c', 'd', 'e', 'f', 'g'];
/*
* 删除指定范围的元素
*   第一个参数:删除的起始位置(包含)
*   第二个参数:从删除元素的起始位置开始,向右删几个
* */
// let res;
// res= a.splice(2, 3); // 删除的元素:  [ 'c', 'd' ]  原数组:  [ 'a', 'b', 'e', 'f', 'g' ]
// console.log('删除的元素: ', res, ' 原数组: ',  a);


/*
* 替换指定范围内的元素
*   第一个参数:起始位置(包含)
*   第二个参数:从起始位置,向右替换几个
*   第三或更个多参数:一个或多个元素将被替换到数组中去
* */
// let res;
// // res= a.splice(0, 2, '沙和尚'); // 删除的元素:  [ 'a', 'b' ]  原数组:  [ '沙和尚', 'c', 'd', 'e', 'f', 'g' ]
// res= a.splice(0, 2, '沙和尚', '白骨精', '蜘蛛精'); // 删除的元素:  [ 'a', 'b' ]  原数组:  [ '沙和尚', '白骨精', '蜘蛛精', 'c', 'd', 'e', 'f', 'g']
// console.log('删除的元素: ', res, ' 原数组: ',  a);


/*
*  向指定位置插入元素
*   第一个参数:在该索引前面插入,值必须大于等于0
*   第二个参数:必须是0,否则就是替换了
*   第三或更个多参数:一个或多个元素将被插入到指定索引下标之前去
* */
// let res;
// // res = a.splice(0, 0, '沙和尚'); // 删除的元素:  [ ]  原数组:  ["沙和尚", "a", "b", "c", "d", "e", "f", "g"]
// res = a.splice(2, 0, '沙和尚', '白骨精', '蜘蛛精'); // 删除的元素:  [ ]  原数组:  ["a", "b", "沙和尚", "白骨精", "蜘蛛精", "c", "d", "e", "f", "g"]
// console.log('删除的元素: ', res, ' 原数组: ', a);

连接数组concat

concat用于连接多个数组,并不会影响原有数组,而是返回新的数组:

javascript
let arr1 = ['a', 'b'];
let arr2 = ['c', 'd'];
let arr3;
arr3 = arr1.concat(arr2); // [ 'a', 'b', 'c', 'd' ]
// 能多次自己连接自己
arr3 = arr1.concat(arr1, arr1, arr1); // [ 'a', 'b', 'a', 'b', 'a', 'b' ]
// 还能拼接单个值
arr3 = arr1.concat(arr1, 'x', 'y'); // [ 'a', 'b', 'a', 'b', 'x', 'y' ]
console.log(arr3);

数组去重

javascript
let arr = ['a', 'b', 'a', 'b', 'e', 'e', 'b'];

// 法1 利用临时数组和includes
function func1(arr) {
    let tmpArr = [];
    for (let i of arr) {
        if (!tmpArr.includes(i)) {  // 使用 ! 取反
            tmpArr.push(i)
        }
    }
    return tmpArr;
}

console.log(func1(arr)); // [ 'a', 'b', 'e' ]

// 法2,利用临时数组和indexOf
function func2(arr) {
    let tmpArr = [];
    for (let i of arr) {
        if (tmpArr.indexOf(i) === -1) {  // 使用 ! 取反
            tmpArr.push(i)
        }
    }
    return tmpArr;
}

console.log(func2(arr)); // [ 'a', 'b', 'e' ]

// 法3,原地删除,循环数组,拿到当前的元素和它后面的元素比较,如果一样,就删除后面的数字
function func3(arr) {
    for(let i = 0; i < arr.length; i++) {
        for (let j = i + 1; j < arr.length; j++) {
            if (arr[i] === arr[j]) {
                arr.splice(j, 1);
                // 当删除一个元素后,后面的元素索引都会自动向左移动,可能会导致遗漏的元素
                // 所以 j-- 一下,让当前索引再次比较一下
                j--;
            } 
        }
    }
    return arr
}
console.log(func3(arr)); // [ 'a', 'b', 'e' ]

String

在js的基础部分我们说了字符串的基本定义语句,这里我们集中来说说字符串的常用方法。

因为字符串是不可变类型,所以,它的方法都是非破坏性方法。

连接字符串:concat

对多个字符串进行拼接,并且返回新的字符串。

javascript
let s1 = 'hello';
let s2 = 'world';
let res;
res = s1.concat(s2); // helloworld
res = s1.concat(s2, 'hahaha', 'heiheihei'); // helloworldhahahaheiheihei
console.log(res);

根据索引获取字符charAt

根据索引下标返回对应的字符,跟str[0]这种类似。

javascript
let s1 = 'hello';
let res;
res = s1.charAt(0); // h
res = s1.charAt(4); // o
res = s1.charAt(-1); // 没有索引为-1,所以返回空
res = s1.charAt(10); // 超出索引范围,所以返回空
console.log(res);

根据索引下标返回字符在字符编码表的编码位置:charCodeAt

根据索引下标,返回对应字符在字符编(不仅限于ASCII)码表上的编码位置:

javascript
let s1 = 'hello';
let res;
// res = s1.charCodeAt(0); //  h --> 104
// res = s1.charCodeAt(4); // o --> 111
// res = s1.charCodeAt(-1); // 没有索引为-1,所以返回 NaN
res = s1.charCodeAt(10); // 超出索引范围,所以返回 NaN
console.log(res);

既然能根据字符返回编码位置,反过来也能根据编码位置对应的字符:

javascript
console.log(String.fromCharCode(104)); // h
console.log(String.fromCharCode(111)); // o
console.log(String.fromCharCode(38169)); // 错

判断字符串中是否含有指定子串:indexOf/lastIndexOf

javascript
let s1 = 'hello world';
let res;
// 默认从左到右找到第一个符合条件的字符的索引下标,找不到就返回 -1
res = s1.indexOf('o'); // 4
res = s1.indexOf('z'); // -1

// 也可以指定从左到右的起始位置
res = s1.indexOf('o', 6); // 7    从索引下标为6开始往右找

// 也可以找子串在字符串第一次出现的位置
res =s1.indexOf('llo'); // 2

// 从右往左找到一个符合条件的字符的索引下标,找不到就返回 -1
// 其它用法跟indexOf用法一样,这里不在演示
res = s1.lastIndexOf('l'); // 9
console.log(res);

字符串截取:slice

从字符串中截取指定范围的子串,并返回截取结果,并不影响原字符串。

javascript
let s1 = 'hello world';
let res;
// 指定截取开始位置和结束位置,注意,尾部截取不到,即不包含尾部
res = s1.slice(0, 2); // he
console.log(res);

以指定字符分割字符串:split

以指定字符分割字符串,并以数组的形式返回分割结果。

javascript
let s1 = 'hello world';
let res;
res = s1.split(" "); // [ 'hello', 'world' ]
console.log(res);

let s2 = 'a,b,c,d,e,f';
res = s2.split(","); // [ 'a', 'b', 'c', 'd', 'e', 'f' ]
console.log(res);

返回字符串小写/大写:toLowerCase/toUpperCase

javascript
let s1 = 'Hello1W2o3rld';
let res;
// 返回字符串的大写字母小写结果
res = s1.toLowerCase(); // hello1w2o3rld

// 返回字符串的小写字母大写结果
res = s1.toUpperCase(); // HELLO1W2O3RLD
console.log(res);

去除字符串两边的空格:trim

去空格的方法是新出的,所以兼容性不太好,这点需要注意。

javascript
let s1 = ' Hello1 W2o3rld\n';
let res;
// 默认去除字符串两边的空格和\n
res = s1.trim(); // Hello1 W2o3rld

// 仅去除字符串一边的空格或者\n
res = s1.trimEnd();
res = s1.trimStart();
console.log(res);

判断字符以什么开头结尾:startsWith/endsWitch

javascript
let s1 = 'Hello1 W2o3rld';
let res;
// 判断字符串是否以指定字符开头
res = s1.startsWith('H'); // true

// 判断字符串是否以指定字符结尾
res = s1.endsWith('d'); // true
console.log(res);

Object

在JavaScript中,对象object类似于Python中的字典。

对象的更新

javascript
// 这里主要介绍几种更新形式
// 第一种,就是用一个对象覆盖当前对象
let obj1 = { k1: "v1", k2: "", }
let obj2 = { k2: "v22", k3: "v3", }
// obj2覆盖obj1中的所有键值对
obj1 = {...obj2}
console.log('obj1', obj1)  // {k2: 'v22', k3: 'v3'}
console.log('obj2', obj2)  // {k2: 'v22', k3: 'v3'}

// 第二种,就是用一个对象更新当前对象,如果key存在,就覆盖其value,如果key不存在,就添加上该键值对
let obj1 = { k1: "v1", k2: "v2", }
let obj2 = { k2: "v22", k3: "v3", k4: {k44: 'v44'}}
// obj2更新obj1
Object.assign(obj1, obj2)
// 缺点是浅拷贝,也就是有嵌套对象时,只会拷贝其内存地址,如果嵌套对象有被修改,则会影响所有的相关对象
obj2.k4.k44 = 'v444'
console.log('obj1', obj1)  // {k1: 'v1', k2: 'v22', k3: 'v3', k4: {k44: 'v444'}}
console.log('obj2', obj2)  // {k2: 'v22', k3: 'v3', k4: {k44: 'v444'}}

// 第三种,解决上面浅拷贝的问题,那就是深拷贝
<!-- 深拷贝可以用lodash这个三方库来做,用之前先引入 -->
<script src="https://cdn.bootcdn.net/ajax/libs/lodash.js/4.17.21/lodash.js"></script>
<script>
    let obj1 = {k1: "v1", k2: "v2",}
    let obj2 = {k2: "v22", k3: "v3", k4: {k44: 'v44'}}
    // obj2更新obj1
    // lodash用的时候,就是_.cloneDeep(obj2)
    obj1 = _.cloneDeep(obj2)
    // 缺点是浅拷贝,也就是有嵌套对象时,只会拷贝其内存地址,如果嵌套对象有被修改,则会影响所有的相关对象
    obj2.k4.k44 = 'v444'
    console.log('obj1', obj1)  // {k1: 'v1', k2: 'v22', k3: 'v3', k4: {k44: 'v44'}}
    console.log('obj2', obj2)  // {k2: 'v22', k3: 'v3', k4: {k44: 'v444'}}
</script>

Math

https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Math

Math 是一个内置对象,它拥有一些数学常数属性和数学函数方法。Math 不是一个函数对象。我们可以当成工具类来使用。

这里只介绍常用的一些属性和方法,更多的参考上面的连接。

javascript
// 圆周率
// console.log(Math.PI); // 3.141592653589793

// 绝对值
// console.log(Math.abs(-10)); // 10

// 向上取整
// console.log(Math.ceil(3.6)); // 4

// 向下取整
// console.log(Math.floor(3.6)); // 3

// 四舍五入
// console.log(Math.round(3.6)); // 4
// console.log(Math.round(3.4)); // 3

// 多个值中求最大
// console.log(Math.max(1, 4, 3)); // 4

// 多个值中求最小
// console.log(Math.min(1, 4, 3)); // 1

// x的y次方
// console.log(Math.pow(2, 3)); // 8

// 平方根
// console.log(Math.sqrt(2)); // 1.4142135623730951

random

javascript
// 生成0~1之间的随机数,测试结果来看,不包含0和1
let r;
r = Math.random();

// 生成0~n之间的随机数,包含0和n
// r = Math.round(Math.random() * 5);

// 生成 n~m之间的随机数,包含n和m
function ran(n, m) {
    // 下面的式子是推算出来的
    return Math.round(Math.random() * (m - n)) + n;
}
// console.log(ran(3, 8));

// 通过随机数进行打乱有序数组
let arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
arr.sort(function (a, b) {
    return Math.random() - Math.random();
});
console.log(arr); // [ 1,  6, 2, 3, 7, 4, 10, 8, 9, 5 ]

Date

https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Date

创建一个 JavaScript Date 实例,该实例呈现时间中的某个时刻。Date 对象则基于 Unix Time Stamp,即自1970年1月1日(UTC)起经过的毫秒数。

日期时间

javascript
// 当前时间
// let d = new Date(); // Fri Aug 13 2021 20:37:26 GMT+0800 (中国标准时间)

// 指定的日期和时间, 日期字符串格式 ‘月/日/年(4位的年) 时:分:秒’
// let d = new Date('2021-8-8'); // Sun Aug 08 2021 00:00:00 GMT+0800 (中国标准时间)
// let d = new Date('2021/8/8'); // Sun Aug 08 2021 00:00:00 GMT+0800 (中国标准时间)
// let d = new Date('8/8/2021'); // Sun Aug 08 2021 00:00:00 GMT+0800 (中国标准时间)
// let d = new Date('8/8/2021 8:8:8'); // Sun Aug 08 2021 08:08:08 GMT+0800 (中国标准时间)
// console.log(d);

// 获取日期对象的周几,返回0~6,周日~周六
// let d1 = new Date(); // 最新的日期对象
// console.log(d1.getDay());  // 5  周五
// let d2 = new Date('8/8/2018');
// console.log(d2.getDay());  // 3  2018年8月8号是周三
// 返回个数字肯定不太好,比如页面要显示周几或者星期几之类的,就可以巧用数组和索引来处理
// let weekName = ['周日', '周一', '周二', '周三', '周四', '周五', '周六'];
// console.log(weekName[d1.getDay()]); // 周五


// 获取当前的日期
// let d = new Date();
// console.log(d.getDate()); // 13
// 获取当前的月份,返回值有点特殊
// 返回值是 0~11,1月~12月
// console.log(d.getMonth()); // 7
// console.log(d.getMonth() + 1); // 8 当前月份可以手动加一
// 获取四位的年份
// console.log(d.getFullYear()); // 2021
// 获取时/分/秒
// console.log(d.getHours()); // 20  晚上8点
// console.log(d.getMinutes()); // 54  分
// console.log(d.getSeconds()); // 31  秒

let d = new Date();
// 从1970/1/1 00:00:00 到现在经历的秒数
console.log(d.getTime()); // 1628859658254
// 获取当前的时间戳
console.log(Date.now()); // 1628860267198

解构赋值

新语法,将数组或者对象中的元素和变量一一对应:

javascript
// 基础用法
// let [a, b, c] = [1, 2, 3];
// console.log(a, b, c); // 1 2 3

// 其他用法
let [a, b, ...c] = [1, 2, 3, 4, 5, 6, 7];
console.log(a, b, c); // 1 2 [ 3, 4, 5, 6, 7 ]

// 交换位置
let arr = ['a', 'b', 'c'];
[arr[0], arr[1]] = [arr[1], arr[0]];
console.log(arr); // [ 'b', 'a', 'c' ]

// 打散数组,解构赋值
function sum(a, b, c) {
    return a + b + c;
}
let arr2 = [1, 2, 3];
console.log(sum(...arr2)); // 6

// 解构赋值在对象中的用法
let obj = {name: '孙悟空', age: 18, gender: "male"};
let {name, age, gender} = obj;
console.log(name, age, gender); // 孙悟空 18 male