【JavaScript】ECMAS6(ES6)新特性概览(二):解构赋值、扩展与收集、class类全面解析

在这里插入图片描述

🔥 个人主页:空白诗
🔥 热门专栏:【JavaScript】

在这里插入图片描述

文章目录

    • 🌿 引言
    • 五、 Destructuring Assignment - 解构赋值,数据提取的艺术 🎨
      • 📌 数组解构
      • 📌 对象解构
      • 📌 特殊用法与技巧
      • 📌 小结
    • 六、 Spread and Rest Operators - 扩展与收集,数组操作新境界 🌀
      • 📌 扩展运算符
      • 📌 剩余参数
      • 📌 高级用法与技巧
      • 📌 小结
    • 七、 Class类 - 面向对象编程,正式登场 👑
      • 📌 构造函数与实例化
      • 📌 方法
      • 📌 Getter 和 Setter
      • 📌 继承
      • 📌 静态方法和属性
    • 总结

在这里插入图片描述

🌿 引言

ES6,作为ECMAScript 2015的简称,标志着JavaScript编程语言的一个重要进化节点。它不是渐进的变化,而是一次飞跃式的更新,为开发者带来了一系列强大的新特性与语法糖,极大提升了代码的简洁性、可读性和运行效率。从新的变量声明方式letconst,到优雅的箭头函数模板字符串,再到让对象操作更为灵活的解构赋值增强的对象字面量ES6的每项改进都旨在让JavaScript适应日益复杂的应用场景,同时保持其作为脚本语言的活力与魅力。本文是深入探索这些核心特性的起点,为你铺开一条通向高效、现代JavaScript编程实践的道路。

继上文👉🏻 【JavaScript】ECMAS6(ES6)新特性概览(一):变量声明let与const、箭头函数、模板字面量全面解析 后,我们将继续深入探讨ECMAS6的其他关键特性,涵盖解构赋值、扩展与收集、面向对象编程的Class体系,进一步加深对现代JavaScript编程的理解与应用能力。


五、 Destructuring Assignment - 解构赋值,数据提取的艺术 🎨

解构赋值作为ES6引入的一项强大特性,彻底革新了数据访问与赋值的方式,使得从数组或对象中提取数据变得既直观又高效。这项技术不仅简化了代码,还大大增强了JavaScript的表达能力。

📌 数组解构

数组解构允许你将数组中的元素直接赋值给不同变量。你可以解构任意长度的数组,甚至忽略某些值或使用默认值。

const [first, , third, fourth = "default"] = [1, 2, 3, 4];
console.log(first, third, fourth); // 输出:1 3 4
// 注意:第二个元素被忽略,第四个元素使用了默认值

📌 对象解构

对象解构则让你能够将对象的属性值直接绑定到变量上,匹配属性名即可。这在处理API响应或配置对象时尤为有用。

const {a, b: aliasForB, c = "defaultValue"} = {a: 5, b: 6};
console.log(a, aliasForB, c); // 输出:5 6 defaultValue
// 注意:`b`属性值被赋给了新命名的变量`aliasForB`,`c`使用了默认值

📌 特殊用法与技巧

  • 交换变量值:无需临时变量,直接交换两个变量的值。

    let x = 1, y = 2;
    [x, y] = [y, x];
    console.log(x, y); // 输出:2 1
    
  • 默认值与解构:为了解构时避免undefined,可以为解构的变量设置默认值。

    function fetchUserData({id = 0, name = "Guest", email}) {
        console.log(id, name, email);
    }
    
    fetchUserData({id: 123}); // 输出:123 Guest undefined
    
  • 嵌套解构:对于嵌套结构,可以连续使用解构表达式。

    const nestedObj = {data: {val1: 1, val2: 2}};
    const {data: {val1, val2}} = nestedObj;
    console.log(val1, val2); // 输出:1 2
    

📌 小结

解构赋值是JavaScript中一种高级且实用的数据操作方式,它简化了数据处理逻辑,提升了代码的可读性和简洁性。无论是处理数组、对象还是更复杂的嵌套结构,解构赋值都展现了其“数据提取艺术”的魅力,是现代JavaScript编程不可或缺的一部分。掌握并灵活运用解构赋值,将使你的编码之旅更加优雅与高效。


六、 Spread and Rest Operators - 扩展与收集,数组操作新境界 🌀

扩展运算符(...)与剩余参数(...)是JavaScript ES6引入的两项强大特性,它们彻底改变了数组处理与函数参数的灵活性,为开发者提供了更加高效与优雅的工具。

📌 扩展运算符

扩展运算符允许你将数组或可迭代对象(如数组、Set、Map)的内容“展开”到另一个数组或作为函数的参数列表中,实现数组合并或克隆取值等操作。

// 数组合数组
const arr1 = [1, 2, 3];
const arr2 = [4, 5];
const combined = [...arr1, ...arr2];
console.log(combined); // 输出:[1, 2, 3, 4, 5]

// 函数参数展开
function multiply(a, b, c) {
    return a * b * c;
}
const numbers = [2, 3];
console.log(multiply(...numbers, 4)); // 输出:24

📌 剩余参数

剩余参数则是形参的一种特殊形式,使用三个点...标识,用于收集函数调用时多余的参数到一个数组中,非常适合不确定参数数量的场景。

function sum(...numbers) {
	// 使用reduce方法累加数组中的所有元素
    return numbers.reduce((accumulator, currentValue) => accumulator + currentValue, 0);
}
console.log(sum(1, 2, 3, 4)); // 10

📌 高级用法与技巧

  • 对象复制与合并:扩展运算符可以用于浅复制对象或合并多个对象。

    const obj1 = {a: 1};
    const obj2 = {b: 2};
    const merged = {...obj1, ...obj2}; // 输出:{a: 1, b: 2}
    
  • 解构与剩余:在解构赋值中结合剩余参数,可以收集解构未明确列出的属性。

    const {a, ...rest} = {a: 1, b: 2, c: 3};
    console.log(rest); // 输出:{b: 2, c: 3}
    

📌 小结

扩展运算符与剩余参数不仅简化了数组操作和函数参数处理,还为JavaScript代码带来了更高的灵活性和表达力。通过它们,你可以轻松地合并数组、复制对象、收集不定参数,甚至实现复杂的逻辑,这些都是现代JavaScript开发不可或缺的技能。掌握这两项特性,你的代码将更加高效且易于维护。


七、 Class类 - 面向对象编程,正式登场 👑

ES6 引入了 class 关键字,标志着JavaScript正式拥抱了面向对象编程(OOP)的设计模式,使得定义和继承类变得更加直观和规范。尽管JavaScript本质上仍基于原型继承,但class语法提供了一个熟悉且易于理解的接口,让习惯于Java、C#等语言的开发者能更快上手。

这里只做一些简单介绍,更多关于 class 类的内容在之前的一篇博客 JavaScript 中的 Class 类 中有更为详细的介绍。

📌 构造函数与实例化

每个class内部可以定义一个特殊的constructor方法,它是类的构造函数,用于初始化新创建的实例。当使用new关键字创建类的实例时,构造函数会被自动调用。

class Person {
    constructor(name, age) {
        this.name = name; // 使用this关键字给实例添加属性
        this.age = age;
    }
}

const bob = new Person('Bob', 25); // 实例化Person类

📌 方法

类中可以定义方法,这些方法就是类的原型上的函数,可以被所有实例共享。

class Person {
    // ... 构造函数代码 ...
    
    sayHello() {
        console.log(`Hello, my name is ${this.name} and I am ${this.age} years old.`);
    }
}

bob.sayHello(); // 输出:Hello, my name is Bob and I am 25 years old.

📌 Getter 和 Setter

ES6允许在类中定义gettersetter方法,用来更安全、灵活地访问和修改对象的属性。

class User {
    constructor(firstName, lastName) {
        this.firstName = firstName;
        this.lastName = lastName;
    }

    get fullName() {
        return `${this.firstName} ${this.lastName}`;
    }

    set fullName(name) {
        const parts = name.split(' ');
        this.firstName = parts[0];
        this.lastName = parts[1];
    }
}

const user = new User('John', 'Doe');
console.log(user.fullName); // 输出:John Doe
user.fullName = 'Jane Smith';
console.log(user.firstName); // 输出:Jane

📌 继承

ES6的类继承机制通过extends关键字实现,子类可以继承父类的所有属性和方法,并可以通过super关键字调用父类的构造函数和方法。

class Employee extends Person {
    constructor(name, age, position) {
        super(name, age); // 调用父类构造函数
        this.position = position;
    }

    work() {
        console.log(`${this.name} is working as a ${this.position}.`);
    }
}

const jane = new Employee('Jane', 30, 'Developer');
jane.sayHello(); // 输出:Hello, my name is Jane and I am 30 years old.
jane.work(); // 输出:Jane is working as a Developer.

📌 静态方法和属性

类还可以拥有静态方法和属性,它们不属于实例,而是属于类本身,通过类直接调用。

class Helper {
    static calculateAge(birthYear) {
        return new Date().getFullYear() - birthYear;
    }
}

console.log(Helper.calculateAge(1990)); // 输出当前年份减去1990的结果

通过这些特性,ES6class语法不仅为JavaScript带来了更符合直觉的面向对象编程模型,同时也保留了其灵活性和动态性,为开发者提供了强大的工具箱,以构建复杂的、可维护的应用程序。


总结

本文是关于ECMAS6JavaScript编程语言中引入的重要特性和改进的深入探讨。ES6代表了JavaScript语言的一次重大升级,它引入了多种新特性来提升代码的简洁性、可读性及执行效率,从而更好地应对复杂的应用场景。

  • 解构赋值解构赋值ES6中一项革命性的特性,它允许直接从数组或对象中提取值到变量中。这一特性简化了数据处理逻辑,提升了代码的清晰度。例如,可以轻易地交换变量值、为解构的变量提供默认值以及处理嵌套结构,极大地丰富了数据操作的方式。

  • 扩展与剩余运算符扩展运算符和剩余参数通过...语法提供了数组操作和函数参数处理的新维度。扩展运算符可以用于数组合并、克隆以及对象的浅复制与合并,而剩余参数则允许收集函数调用时多余的参数。这两者联合使用,让JavaScript代码在处理集合类型数据和灵活接受参数方面变得前所未有的强大和灵活。

  • 面向对象编程(Class)ES6通过引入class关键字,正式将面向对象编程的概念以一种更接近传统面向对象语言的语法形式带入JavaScript。尽管JavaScript的继承机制本质上仍是基于原型,class语法却提供了更直观的类定义和继承方式,包括构造函数、方法定义、getter/setter、继承(通过extendssuper关键字)、以及静态方法和属性的支持。这让熟悉Java、C#等语言的开发者能快速上手,并促进代码的组织和复用,特别是在构建大型应用程序时。

综上所述,ES6通过解构赋值扩展与剩余运算符、以及面向对象编程Class体系等关键特性,为JavaScript开发者装备了强大的工具,不仅现代化了代码风格,也极大地提高了开发效率和代码质量。这些特性共同推动JavaScript向更成熟、更健壮的编程语言发展,适应了不断变化的技术需求和日益增长的项目复杂度。

后续我们将继续深入了解ES6新特性,例如Modules模块系统、异步处理promise、生成器函数generatorsmapset数据结构…等等。当然其中有些内容在之前的博客也有详细探讨过,内容都在👉🏻 🔥 专栏:【JavaScript】。感谢大家支持~ ❤️

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/658946.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

matlab生成波形然后采样,FPGA写testbench读取数据

一、在matlab产生激励 fs1000; % 这个是路数 M16; % 这个是FFT的点数,64K L65536; % 将N写为两个整数乘积的形式,即N ML,(log2 M和log2 L都为正整数) NM*L; % 这段 MATLAB 代码是用来生成一个时间序列的, % 该时间序列从0开…

一次性把“AI 原生应用技术栈”说明白

AI 当前有多火爆不用介绍了,随着各个厂商的努力,也慢慢浮现了有价值的应用,以及为更好的服务 AI 原始应用准备的各种平台产品。今天这篇简单介绍下当前业界最新的 AI 原生应用技术栈。 特别声明:AI 技术还在快速发展过程中&#…

数据可视化分析工具DataEase

本文软件由网友 雨林 推荐,老苏稍微研究了一下 DataEase 的安装,具体的使用教程,请参考官方的在线文档和教学视频 什么是 DataEase ? DataEase 是开源的数据可视化分析工具,帮助用户快速分析数据并洞察业务趋势&#x…

新品发布(仓库小助手)一机在手,轻松无忧

你是否曾为繁琐的货物管理而烦恼? 你是否为了记录货物信息忙前忙后? 近几年,陆续有收到客户在运营跨境代购中的一些反馈,特别是仓库管理这块,比如包裹的出入库、移库、修改包裹信息等,都需要在电脑上完成&…

HTML新春烟花盛宴

目录 写在前面 烟花盛宴 完整代码 修改文字

轻松掌握图片批量处理,赶紧学习这些小技巧!

在现今数字化的社会中,我们每天都会接触到大量的图片,无论是在工作中还是日常生活中。要想高效处理这些图片,掌握图片批量处理的技巧就显得尤为重要。幸运的是,有许多小技巧和工具可以让这一过程变得轻松愉快。 在本文中&#xf…

解决 Echarts 图 tooltip 层级太高穿透问题

问题场景:Echarts 图 tooltip 是自动轮播的,当点击某个区域出现弹窗时,tooltip和弹窗同时显示,没在遮罩层下面,查看tooltip的层级显示99999,所以这里改一下tooltip的层级。 设置 extraCssText: "z-ind…

白酒:产地的标识对消费者选择的影响与策略

云仓酒庄豪迈白酒作为一款知名品牌,其产地的标识对消费者选择产生着重要的影响。产地的标识是消费者了解和信任产品的重要途径,因此,如何巧妙地运用产地的标识来吸引和留住消费者,是品牌营销的重要策略。 首先,产地的标…

Suno进阶手册 | 创作歌曲玩法全攻略!

Suno进阶手册:创作歌曲玩法全攻略! 前言1. 基础模式2. 高级模式总结前言 前段时间,Suno V3 横空出世,与此前的V2相比,V3生成的作品质量明显提升! 该说不说,对比同类型工具,Suno的体验“遥遥领先”,没有AI生成常有的机械感,歌词押韵,甚至还附带有和声、分段。 虽然…

有免费通配符证书吗?哪里可以申请?

市面上的免费SSL证书大多数为单域名证书,如果您的主域名拥有众多子域名,逐一申请单域名SSL证书不太现实,下面为介绍一款永久免费使用的通配符SSL证书申请流程 1 选择免费通配符证书提供商 免费通配符证书申请点击这里直接获取https://www.…

两年半前端面字节,广度和深度让我不想做前端了

两年半经历,面的是前端工程师,字节面试官的问题挺有广度与深度的,这里整理一下面试过程中的题目(有些忘记了),分享给大家: 面试过程中的问题 1、简单的自我介绍与项目经验。 2、一道算法题。 3、一道 …

ClickHouse安装教程:开启你的列式数据库之旅

ClickHouse是一个高性能的列式数据库管理系统,适用于在线分析处理(OLAP)。以下是ClickHouse的一些基本使用步骤: 下载二进制文件:您可以通过运行以下curl命令在Linux、FreeBSD或macOS上本地下载ClickHouse&#xff1a…

汽车IVI中控开发入门及进阶(二十一):DAB和FM 收音机

前言: 在过去的十年里,数字收音机对车载娱乐产生了重大影响。现在,几乎每辆新车都标配了这项技术,这也是我们60%以上的人收听收音机的方式。甚至有传言称,在不久的将来,将永久关闭调频发射机,使许多车载收音机过时。但一些相对年轻的汽车在工厂里仍然没有安装DAB,而且…

【数值计算方法】雅可比解线性方程

废话少说&#xff0c;直接上干货。 #include <stdio.h> #include <stdlib.h> #include <math.h> #define MaxSize 100 double A[MaxSize][MaxSize]; //系数矩阵 double B[MaxSize]; //系数矩阵 double C[MaxSize][MaxSize]; //去对角线矩阵 double …

LeetCode 377.组合总和Ⅳ

这题是我蠢了&#xff0c;它说是组合数我就信了&#xff0c;言尽于此 class Solution { public:int combinationSum4(vector<int>& nums, int target) {vector<int> dp(2000,0);dp[0]1;for(int i0;i<target;i){for(int j0;j<nums.size();j){if(i>nums…

ABP框架+Mysql(三)

创建,更新和删除图书 创建新书籍 创建 modal form 在 Acme.BookStore.Web 项目的 Pages/Books 目录下新建一个 CreateModal.cshtml Razor页面: CreateModal.cshtml.cs 打开 CreateModal.cshtml.cs 代码文件(CreateModalModel 类),替换成以下代码: using System.Threading.…

各类信息化项目第三方验收测试的作用

验收测试 各类信息化项目第三方验收测试的作用主要体现在以下几个方面&#xff1a; 1. 客观性&#xff1a;第三方验收测试的突出特点是其客观性。与项目开发团队或相关利益方相比&#xff0c;第三方测试机构能够更加客观地进行测试&#xff0c;不受项目具体背景、利益关系等因…

基于langchain+千帆sdk的一个基于文档的QA问答Demo

微信公众号&#xff1a;淼学派对 CSDN&#xff1a;淼学派对 哔哩哔哩&#xff1a;淼学派对 各大博客社区&#xff1a;淼学派对 背景说明 百度智能云千帆大模型平台官方SDK正式对外发布&#xff1a;https://pypi.org/project/qianfan/。同步支持langchain接入千帆api。 本文重点…

JVM的相关知识

目录 JVM内存划分 类加载过程 类加载中的“双亲委派模型” JVM内存划分 JVM也就是java进程。这个进程一旦跑起来之后&#xff0c;就会从操作系统里&#xff0c;申请一大块内存空间。JVM接下来就要进一步的对这个大的空间进行划分。划分成不同区域&#xff0c;从而每个区域都…

Linux服务器安装与配置python环境 最新linux安装python 小白教程

目录 一、下载官网的安装包 二、安装流程 三、配置软连接&#xff08;类似window系统的环境变量&#xff09; 四、可能会出现的问题&#xff1a; 1.ssl连接问题&#xff0c;下图所示&#xff1a; 一、下载官网的安装包 1.官网安装包地址&#xff1a;https://www.python.org/…