ES6之Promise、Class类与模块化(Modules)

目录

  • Promise
  • Class类
    • extends
    • super
  • Modules 模块系统
    • export default 和对应import
    • export 和 import

Promise

  • Promise 是 ES6 引入的一种用于处理异步操作的对象。
    它解决了传统回调函数(callback)模式中容易出现的回调地狱和代码可读性差的问题。

  • Promise 对象有三种状态:

    1. Pending(进行中): 初始化状态,表示异步操作还在进行中。
    2. Fulfilled(已成功): 表示异步操作执行成功,并且返回了一个值。
    3. Rejected(已失败): 表示异步操作执行失败,抛出一个错误或异常。
  • Promise 对象具有以下特点:

    1. Promise 构造函数接收一个执行器函数(executor),该函数具有两个参数:resolve reject
      • 通过调用resolve 函数,将 Promise 对象从进行中状态变为已成功状态;
      • 通过调用 reject 函数,将 Promise 对象从进行中状态变为已失败状态。
    2. then() 方法用于指定异步操作成功后的回调函数,并且可以链式调用多个 then() 方法。每个then() 方法都返回一个新的Promise 对象。
    3. catch() 方法用于指定异步操作失败时的回调函数,也可以链式调用多个 catch() 方法,本质是then的特例。catch() 方法也返回一个新的Promise 对象。
    4. finally() 方法用于指定无论异步操作成功或失败,最终都需要执行的回调函数。finally() 方法也会返回一个新的Promise 对象。
    5. Promise.resolve();Promise.reject();方法;在这里插入图片描述
      • Promise.resolve();参数

        • 参数是Promise实例对象时,直接返回这个Promise对象
        • 参数是具有then方法的对象时,会立即执行它的then方法
        • 参数是其他值时,相当于通过resolve函数传参
      • Promise.reject();参数

        • 不管什么参数,都会原封不动地向后传递,作为后续方法的参数
        const thenable =
        	then(resolve,reject){
        	resolve('success');
        	// reject('reason');
        ;
        Promise.resolve(thenable).then(
        	data => console.log(data),
        	err => console.log(err)
        );
        
    6. Promise.all() 方法接受一个 Promise 数组作为参数(只要是可以遍历的都可以作为参数,下同),返回一个新的 Promise 对象。只有当所有的Promise对象都成功时,才会返回一个成功的结果数组;只要有一个 Promise 对象失败,就会返回一个失败的结果。
    7. Promise.race() 方法接受一个Promise 数组作为参数,返回一个新的 Promise 对象。只要数组中的一个Promise 对象完成(无论成功或失败),就会返回该Promise 对象第一个完成的结果。
    8. Promise.allsettled()方法,数组中的任意一个 Promise 对象完成(无论成功或失败),就会返回该Promise 对象对应的结果。
  • 示例:

    // 创建一个异步操作,2秒后返回结果
    const fetchData = () => {
      return new Promise((resolve, reject) => {
        setTimeout(() => {
          const data = "Hello, Promise!";
          resolve(data);
        }, 2000);
      });
    };
    
    // 调用异步操作,并在操作成功后执行回调函数
    fetchData()
      .then((data) => {
        console.log(data); // 输出: "Hello, Promise!"
      })
      .catch((error) => {
        console.error(error);
      })
      .finally(() => {
        console.log("Promise operation finished.");
      });
    

Class类

在JavaScript中,类(Class)是一种用于创建对象的蓝图。类是一种构造函数的语法糖,它提供了一种更简洁、直观的方式来定义对象和其行为。

通过使用类,可以创建多个具有相同属性和方法的对象,并且可以方便地复用和扩展代码。

以下是使用class关键字定义类的示例:

class Person {
  constructor(name, age) { //constructor是一个特殊的方法,用于在创建对象时初始化对象的属性
    this.name = name;
    this.age = age;
  }

  sayHello() {
    console.log(`Hello, my name is ${this.name} and I'm ${this.age} years old.`);
  }
}

要创建Person类的对象,使用new关键字:

const person1 = new Person('Alice', 25);
const person2 = new Person('Bob', 30);

person1.sayHello(); // 输出:Hello, my name is Alice and I'm 25 years old.
person2.sayHello(); // 输出:Hello, my name is Bob and I'm 30 years old.

extends

通过使用extends关键字,我们可以创建一个继承自另一个类的子类:

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

  study() {
    console.log(`${this.name} is studying in grade ${this.grade}.`);
  }
}

const student = new Student('Carol', 18, '12th');
student.sayHello(); // 输出:Hello, my name is Carol and I'm 18 years old.
student.study(); // 输出:Carol is studying in grade 12th.

super

super 有两种用法:

  1. 在子类的构造函数中,用于调用父类的构造函数。通过 super() 可以在子类的构造函数中调用父类的构造函数,并传递需要的参数。

  2. 在子类中,用于调用父类的方法。通过 super.methodName() 的形式来调用父类中的方法。

示例:

class Animal {
  constructor(name) {
    this.name = name;
  }
  
  getName() {
    return this.name;
  }
  
  speak() {
    console.log(`${this.name} makes a sound`);
  }
}

class Dog extends Animal {
  constructor(name, breed) {
    super(name); // 调用父类的构造函数
    this.breed = breed;
  }
  
  getBreed() {
    return this.breed;
  }
  
  speak() {
    super.speak(); // 调用父类的speak方法
    console.log(`${this.name} barks`);
  }
}

const dog = new Dog('Buddy', 'Labrador Retriever');
console.log(dog.getName()); // 输出: Buddy
console.log(dog.getBreed()); // 输出: Labrador Retriever
dog.speak(); // 输出: Buddy makes a sound \n Buddy barks

注意:

  • 调用父类方法时,super 必须在子类的构造函数或方法内部使用。
  • 静态方法中的 ​super​ 用于调用父类的静态方法,而不是实例方法。只能通过类名来调用静态方法,例如 ​super.staticMethod()​。
  • super代表父类的原型对象
  • 通过super调用父类的方法时,方法的this指向当前的子类实例

Modules 模块系统

在 JavaScript 中,模块(Module)是将一段代码封装成可重用和独立的单元。模块提供了一种组织和管理代码的方式,使代码更易于理解、维护和扩展。

在早期版本的 JavaScript 中,并没有内置的模块系统,但现代的 JavaScript 引擎(如Node.js和浏览器中的ES6模块)已经支持对模块的原生语法和功能。以下是关于模块的一些常见特性:

  1. 导出(Export):模块中的代码可以通过导出机制暴露给其他模块使用。通过使用 export 关键字,我们可以将变量、函数、类等从一个模块中导出。

  2. 导入(Import):模块可以导入来自其他模块的代码。通过使用 import 关键字,我们可以引入其他模块导出的内容,并在当前模块中使用。

  3. 默认导出(Default Export):一个模块可以有一个默认导出,即默认导出一个值(变量、函数、类等)。默认导出不需要使用花括号,而是直接通过 export default 导出,并且可以在导入时使用任意名称

  4. 命名导出(Named Export):除了默认导出,模块还可以使用命名导出。通过给导出的值命名并使用 export 关键字进行导出,其他模块可以通过在导入时使用相应的名称进行引用。

  5. 导入和导出的语法:模块的导入和导出可以有不同的语法形式,具体取决于使用的 JavaScript 平台和环境。在 Node.js 环境中,使用 requiremodule.exportsexports 进行导入和导出;在现代浏览器中,使用 ES6 模块语法,即 importexport 关键字。

示例:

// filename: math.js
export function add(a, b) {
  return a + b;
}

export function subtract(a, b) {
  return a - b;
}

// filename: main.js
import { add, subtract } from './math.js';

console.log(add(5, 3)); // 输出: 8
console.log(subtract(10, 4)); // 输出: 6

export default 和对应import

在 JavaScript 的模块系统中,除了可以使用 export 关键字来导出具名的变量、函数或类以外,还可以使用 export default 关键字来导出一个默认值。导出默认值时,可以在导入时使用任意名称。

用法:

  1. 导出默认值:

    • 在导出模块中,可以使用 export default 导出一个默认值,一个模块仅能有一个默认导出
      // 在导出模块中
      export default "Hello!";  // 导出字符串默认值
      export default {        // 导出对象默认值
        name: "John",
        age: 25
      };
      export default function sayHello() {  // 导出函数默认值
        console.log("Hello!");
      }
      
  2. 导入默认值:

    • 在导入模块中,可以使用任意名称导入默认值。不同于具名导入需要使用花括号 {},默认导入直接将值引入到变量中。
      // 在导入模块中
      import myDefault from "./exportDefaultModule.js";
      console.log(myDefault);  // 输出: "Hello!" 或{ name: "John", age: 25 } 或 函数输出
      
      // 如果导出的是一个对象,则可以直接访问其属性
      import myDefault from "./exportDefaultModule.js";
      console.log(myDefault.name);  // 输出: "John"
      

注意: 导入默认值时不需要使用花括号 {}。而且,在一个模块中,通过 export default 导出的默认值不能直接和其他具名导出一起使用。

// 在导出模块中
const myVar = "Hello!";
export default myVar;        // 正确

export default function() {  // 正确
  console.log("Goodbye!");
}

// 错误示例
export const name = "John";
export default myVar;      // 错误!不能同时具名导出和默认导出
// 在导入模块中
import myDefault, { name } from "./exportDefaultModule.js";   // 错误!不能同时导入默认值和具名导出的变量

import myDefault from "./exportDefaultModule.js";            // 正确

export 和 import

在 JavaScript 的模块系统中,export 用于将模块的内容导出,import 用于导入其他模块的内容。下面是关于 exportimport 的各种用法:

  1. 基本用法:

    • 导出单个变量、函数或类:

      // 在导出模块中
      export const name = "John";
      export function sayHello() {
        console.log("Hello!");
      }
      export class Person {
        constructor(name) {
          this.name = name;
        }
      }
      
    • 导入并使用导出的变量、函数或类:

      // 在导入模块中
      import { name, sayHello, Person } from "./exportModule.js";
      console.log(name); // 输出: "John"
      sayHello(); // 输出: "Hello!"
      const person = new Person("Alice");
      console.log(person.name); // 输出: "Alice"
      
  2. 多个导出:

    • 可以在一个 export 语句中同时导出多个内容:

      export { name, sayHello };
      
    • 在导入时,可以使用相同的语法导入多个内容:

      import { name, sayHello } from "./exportModule.js";
      
  3. 导出导入时起别名:

    • 可以使用 as 关键字为导出和导入的内容设置别名:
      // 在导出模块中
      export { name as myName };
      
      // 在导入模块中
      import { myName as name } from "./exportModule.js";
      console.log(name); // 输出: "John"
      
  4. 整体导入:

    • 通过使用 * 关键字,可以将一个模块的所有导出内容作为单个对象进行导入:
      // 在导入模块中
      import * as myModule from "./exportModule.js";
      console.log(myModule.name); // 输出: "John"
      myModule.sayHello(); // 输出: "Hello!"
      
  5. 同时导入:

    • 当导入模块的内容较多时,可以使用 import 关键字一次性导入多个内容,并将它们作为别名的属性:
      // 在导入模块中
      import { name, sayHello, Person } from "./exportModule.js";
      

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

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

相关文章

数学学习——最优化问题引入、凸集、凸函数、凸优化、梯度、Jacobi矩阵、Hessian矩阵

文章目录 最优化问题引入凸集凸函数凸优化梯度Jacobi矩阵Hessian矩阵 最优化问题引入 例如:有一根绳子,长度一定的情况下,需要如何围成一个面积最大的图像?这就是一个最优化的问题。就是我们高中数学中最常见的最值问题。 最优化…

小白到运维工程师自学之路 第六十五集 (docker-compose)

一、概述 Docker Compose 的前身是 Fig,它是一个定义及运行多个 Docker 容器的工具。可以使用YAML文件来配置应用程序的服务。然后,使用单个命令,您可以创建并启动配置中的所有服务。Docker Compose 会通过解析容器间的依赖关系(…

vmware网络配置

效果: 虚拟机和物理机网络互通; 虚拟机可以上外网 环境: vmware version 17.0.0 Centos 7.9 配置 1,vmware 菜单 - 编辑 - Virtual Network Edit 2, 选择VMnet8 VMnet information:NAT; 勾选2个…

ansible控制主机和受控主机之间免密及提权案例

目录 案例描述 环境准备 案例一--免密远程控制主机 效果展示: 解决方案 1.添加主机 2.通过ssh-key生成密钥对 3.生成ssh-copy-id 4.验证 案例二-----免密普通用户提权 效果展示 解决方案 1.使用普通用户,与案例一 一样,进行发送密钥…

【力扣每日一题】2023.8.2 翻转卡片游戏

目录 题目: 示例: 分析: 代码: 题目: 示例: 分析: 这道题不是什么翻转卡片游戏,这就是纯纯的文字游戏,要是能看懂题目那就是非常简单,接下来我就给大家分…

低代码已经发展到什么水平了?

在数字化转型的浪潮下,企业和组织迫切需要更快速、高效的应用开发方式来满足日益复杂的业务需求。而低代码开发作为一种创新的开发方式,正在引领着应用开发的新潮流。低代码开发允许开发者以可视化的方式快速构建应用,减少了繁琐的代码编写&a…

android 如何分析应用的内存(十五)——Visual Studio Code 调试Android应用

android 如何分析应用的内存(十五)——Visual Studio Code 调试Android 应用 在上一篇文章介绍了jdb调试java应用 接下来介绍用UI界面调试java应用,达到同jdb一样的效果。 同样的UI界面有很多选择,如Eclipse,Android …

数论分块学习笔记

准备开始复习莫比乌斯反演,杜教筛这一部分,先复习一下数论分块 0.随便说说 数论分块可以计算如下形式的式子 ∑ i 1 n f ( i ) g ( ⌊ n i ⌋ ) \sum_{i1}^{n}f(i)g(\lfloor\frac{n}{i}\rfloor) ∑i1n​f(i)g(⌊in​⌋)。 利用的原理是 ⌊ n i ⌋ \lf…

GoogLeNet卷积神经网络-笔记

GoogLeNet卷积神经网络-笔记 GoogLeNet是2014年ImageNet比赛的冠军, 它的主要特点是网络不仅有深度, 还在横向上具有“宽度”。 由于图像信息在空间尺寸上的巨大差异, 如何选择合适的卷积核来提取特征就显得比较困难了。 空间分布范围更广的…

采集数据筛选-过滤不要数据或只保留指定数据

采集文章数据,有时候会遇到一些不需要采集的数据,或者只想采集一些特定的数据,可以使用简数采集器的内容过滤功能,对采集的数据进行筛选,只有符合的数据才采集保留。 可以用于过滤掉一些广告、专题、网站首页等无效数…

ESD防静电监控系统在SMT产线中的应用案例

作为电子厂的关键制造环节之一,SMT(表面贴装技术)产线的效率和质量对企业的竞争力至关重要。为了提高生产线的管理效率和保障生产环境的质量,许多电子厂开始采用MES生产管理系统和ESD防静电监控系统的综合解决方案。 在SMT产线中安…

SpringBoot项目增加logback日志文件

一、简介 在开发和调试过程中,日志是一项非常重要的工具。它不仅可以帮助我们快速定位和解决问题,还可以记录和监控系统的运行状态。Spring Boot默认提供了一套简单易用且功能强大的日志框架logback,本文将介绍如何在Spring Boot项目中配置和…

无涯教程-Perl - 循环语句

在某些情况下,您需要多次执行一个代码块。通常,语句是按顺序执行的:函数中的第一个语句首先执行,然后第二个执行,依此类推。 Perl编程语言提供了以下类型的循环来处理循环需求。 Sr.No.Loop Type & 描述1 while loop在给定条…

浅谈大数据软件的功能性分析

在当今时代的潮流中,工作中遇到大数据处理的时候非常多,因此需要一些大数据分析软件帮助人们进行工作。由于这些软件针对的对象不同,因此使用方法也不同,那么为了帮助更多的人了解大数据分析软件,我们就对这些软件的功…

Spring Cloud+Spring Boot+Mybatis+uniapp+前后端分离实现知识付费平台免费搭建 qt

Java版知识付费源码 Spring CloudSpring BootMybatisuniapp前后端分离实现知识付费平台 提供职业教育、企业培训、知识付费系统搭建服务。系统功能包含:录播课、直播课、题库、营销、公司组织架构、员工入职培训等。 提供私有化部署,免费售…

【3维视觉】3D空间常用算法(点到直线距离、面法线、二面角)

3D空间点到直线的距离 3D空间点到直线的距离 3D空间的曲率 三维空间有三个基本元素,点,线,面。那么曲率是如何定义的呢? 点的曲率? 线的曲率? 面的曲率? 法曲率 设曲面上的曲线在某一点处的切…

prometheus+grafana进行服务器资源监控

在性能测试中,服务器资源是值得关注一项内容,目前,市面上已经有很多的服务器资 源监控方法和各种不同的监控工具,方便在各个项目中使用。 但是,在性能测试中,究竟哪些指标值得被关注呢? 监控有…

Git下:Git命令使用-详细解读

今天给大家讲一讲 Git常用命令的使用说明,希望本篇文章对大家有所帮助。 一、Git 安装 Git 的详细安装教程:见上一篇文章《Git上:Git安装教程》: Git上:全网最全最详细的Git安装教程,建议收藏保存 二、…

TDosCommand 组件来执行 JavaScript 脚本(nodejs)

可以在 Delphi 中使用 TDosCommand 组件来执行 JavaScript 脚本。但是,由于 JavaScript 是一种脚本语言,它通常在浏览器中运行,因此您需要使用一种 JavaScript 引擎来执行 JavaScript 脚本。常见的 JavaScript 引擎有 Node.js、Rhino、V8 等等…

面试题学习以及问题

redis redis缓存 缓存穿透 布隆过滤器主要是用于检索一个元素是否在一个集合中。我们当时使用的是 redisson实现的布隆过滤器。 它的底层主要是先去初始化一个比较大数组,里面存放的二进制0或1。在一 开始都是0,当一个key来了之后经过3次hash计算&…