ES6新特性:变量的解构赋值

文章目录

  • [1 数组的解构赋值](#1 数组的解构赋值)
    • [1.1 基本用法](#1.1 基本用法)
    • [1.2 交换变量的值](#1.2 交换变量的值)
    • [1.3 注意事项](#1.3 注意事项)
  • [2 对象的解构赋值](#2 对象的解构赋值)
    • [2.1 基本用法](#2.1 基本用法)
    • [2.2 属性重命名](#2.2 属性重命名)
    • [2.3 注意事项](#2.3 注意事项)

ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring)。

ES6的变量解构赋值是指通过解构的方式将数组或对象中的值赋值给变量。

1 数组的解构赋值

1.1 基本用法

数组的解构赋值可以通过以下语法实现:

javascript 复制代码
let arr = [1, 2, 3];
let [a, b, c] = arr;
console.log(a); // 1
console.log(b); // 2
console.log(c); // 3

在上述语法中,我们将数组 arr 中的值通过方括号的方式进行解构,并将值分别赋值给变量 a, bc

1.2 交换变量的值

javascript 复制代码
let a = 1;
let b = 2;
[a, b] = [b, a];
console.log(a); // 2
console.log(b); // 1

1.3 注意事项

  • 变量与数组元素从左向右一一对应。

    js 复制代码
    let arr = [1, 2, 3];
    let [b, c] = arr;
    console.log(b); // 1
    console.log(c); // 2
  • 当我们需要省略一些元素时,可以使用逗号来跳过这些元素

    javascript 复制代码
    let arr = [1, 2, 3];
    let [, b, c] = arr;
    console.log(b); // 2
    console.log(c); // 3

2 对象的解构赋值

2.1 基本用法

对象的解构赋值可以通过以下语法实现:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>ES6新特性: 解构赋值</title>
</head>

<body>
    <script>
        let obj = {
            name: 'Alice',
            age: 20,
            func: function () {
                console.log(name + '今年' + age + '岁')
            }
        };
        let { name, age, func } = obj;
        console.log(name); // 'Alice'
        console.log(age); // 20
        console.log(func);
    </script>
</body>

</html>

在上述代码中,我们将对象 obj 中的属性通过花括号的方式进行解构,并将属性值分别赋值给变量 nameagefunc。控制台输出如下:

2.2 属性重命名

我们也可以在对象解构赋值时,将属性进行重命名,语法格式为:成员名: 新名

在下面代码中,name: n 表示将 name 属性重命名为 nage: a 表示将 age 属性重命名为 a

示例:

javascript 复制代码
let obj = {
    name: 'Alice',
    age: 20,
    func: function () {
        console.log(name + '今年' + age + '岁')
    }
};
let { name: n, age: a, func: f } = obj;
console.log(n); // 'Alice'
console.log(a); // 20
console.log(f);

得到同样的结果👇

2.3 注意事项

  • 花括号内的变量名要与对象的成员变量或成员方法名称一致
  • 花括号内的变量顺序可以任意
  • 花括号内的变量数量可以少于对象的成员数量,但是当花括号内的变量调用了其他成员的时候,需要同时在花括号内包含调用的成员。

示例:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>ES6新特性: 解构赋值</title>
</head>

<body>

    <script>
        let obj = {
            name: 'Alice',
            age: 20,
            func1: function () {
                console.log(name + '今年' + age + '岁')
            },
            func2: function () {
                console.log('我是func2')
            }
        };
        
        let { name, func1, age } = obj;
        func1();

        let { func2 } = obj;
        func2();
    </script>

</body>

</html>

输出:

html 复制代码
Alice今年20岁
我是func2

点击此处,获取关于ES6变量解构赋值的更多内容。

相关推荐
神奇夜光杯1 分钟前
Python酷库之旅-第三方库Pandas(208)
开发语言·人工智能·python·excel·pandas·标准库及第三方库·学习与成长
TttHhhYy8 分钟前
vue写后台管理系统,有个需求将所有的$message消息提示换成确认框来增强消息提示效果,遇到嵌套过多的情况,出现某些问题
前端·javascript·vue.js·anti-design-vue
yangpipi-10 分钟前
数据结构(C语言版)-2.栈和队列
c语言·开发语言·数据结构
还在学习进步13 分钟前
C语言第九周课——经典算法
c语言·开发语言·算法
阿七想学习16 分钟前
数据结构《链表》
java·开发语言·数据结构·学习·链表
极客代码18 分钟前
【Python TensorFlow】进阶指南(续篇二)
开发语言·人工智能·python·深度学习·tensorflow
亿牛云爬虫专家27 分钟前
如何在Puppeteer中实现表单自动填写与提交:问卷调查
javascript·爬虫·爬虫代理·puppeteer·问卷调查·代理ip·表单
计算机学姐31 分钟前
基于Python的高校成绩分析管理系统
开发语言·vue.js·后端·python·mysql·pycharm·django
VertexGeek33 分钟前
Rust学习(三):rust基础Ⅱ
开发语言·学习·rust
一个数据小开发38 分钟前
业务开发问题之ConcurrentHashMap
java·开发语言·高并发·map