当前位置: 首页 > news >正文

JavaScript 高级教程:异步编程、面向对象与性能优化

在前两篇教程中,我们学习了 JavaScript 的基础和进阶内容。这篇文章将带领你进入更深层次,学习 JavaScript 的异步编程模型、面向对象编程(OOP),以及性能优化的技巧。这些内容对于构建复杂、流畅的前端应用至关重要。


一、异步编程

1. 异步编程模型简介

JavaScript 是单线程的,但它可以通过事件循环(Event Loop)机制实现异步操作。常见的异步方式包括:

  • 回调函数
  • Promise
  • async/await

2. Promise:优雅的异步解决方案

Promise 是异步操作的核心。它可以使代码从嵌套的回调地狱中解脱出来。

示例:

const fetchData = () => {return new Promise((resolve, reject) => {setTimeout(() => {const success = true; // 模拟成功或失败if (success) {resolve("数据加载成功!");} else {reject("数据加载失败!");}}, 2000);});
};fetchData().then((data) => {console.log(data); // 输出:数据加载成功!}).catch((error) => {console.error(error); // 如果失败,输出:数据加载失败!});

要点

  • resolve 表示成功,reject 表示失败。
  • then 用于处理成功,catch 用于捕获错误。

3. async/await:更直观的异步写法

async/await 是对 Promise 的语法糖,代码更简洁。

示例:

const fetchData = () => {return new Promise((resolve, reject) => {setTimeout(() => resolve("数据加载成功!"), 2000);});
};const loadData = async () => {try {const data = await fetchData();console.log(data); // 输出:数据加载成功!} catch (error) {console.error(error); // 捕获错误}
};loadData();

优点

  • 更像同步代码,易读性高。
  • try/catch 捕获错误。

4. 综合案例:加载用户数据

const fetchUserData = async () => {try {const response = await fetch("https://jsonplaceholder.typicode.com/users");const users = await response.json(); // 转换为 JSONconsole.log(users); // 打印用户数据} catch (error) {console.error("数据加载失败:", error);}
};fetchUserData();

二、面向对象编程(OOP)

1. JavaScript 中的类与对象

ES6 引入了 class 语法,使面向对象编程更简洁。

示例:

class Person {constructor(name, age) {this.name = name;this.age = age;}introduce() {console.log(`我是 ${this.name},今年 ${this.age} 岁。`);}
}const alice = new Person("Alice", 25);
alice.introduce(); // 输出:我是 Alice,今年 25 岁。

要点

  • constructor 是构造函数,用于初始化对象属性。
  • 方法定义在 class 中,所有实例共享这些方法。

2. 继承

通过 extends 关键字实现类的继承。

示例:

class Animal {constructor(name) {this.name = name;}speak() {console.log(`${this.name} 发出了声音!`);}
}class Dog extends Animal {speak() {console.log(`${this.name} 说:汪汪!`);}
}const dog = new Dog("小狗");
dog.speak(); // 输出:小狗 说:汪汪!

要点

  • 子类可以重写父类的方法。
  • 子类中使用 super 调用父类方法或构造函数。

3. 封装与私有属性

通过私有属性隐藏内部实现细节,ES2021 引入了 # 作为私有属性的标志。

示例:

class BankAccount {#balance = 0; // 私有属性deposit(amount) {this.#balance += amount;console.log(`存入:${amount},余额:${this.#balance}`);}withdraw(amount) {if (amount > this.#balance) {console.log("余额不足!");} else {this.#balance -= amount;console.log(`取出:${amount},余额:${this.#balance}`);}}
}const account = new BankAccount();
account.deposit(100); // 输出:存入:100,余额:100
account.withdraw(50); // 输出:取出:50,余额:50
// console.log(account.#balance); // 报错:无法访问私有属性

三、性能优化

在开发大型应用时,性能优化非常重要。以下是几种常见的优化技巧。


1. 减少 DOM 操作

频繁的 DOM 操作会降低性能,建议批量更新 DOM 或使用虚拟 DOM。

示例:

// 使用文档片段批量操作 DOM
const fragment = document.createDocumentFragment();
for (let i = 0; i < 1000; i++) {const div = document.createElement("div");div.textContent = `第 ${i + 1} 个元素`;fragment.appendChild(div);
}
document.body.appendChild(fragment);

2. 使用节流(throttle)和防抖(debounce)

节流防抖用于优化高频触发的事件(如滚动或输入)。

节流:限制触发频率

const throttle = (func, delay) => {let last = 0;return (...args) => {const now = Date.now();if (now - last >= delay) {last = now;func(...args);}};
};window.addEventListener("resize", throttle(() => {console.log("窗口大小变化!");
}, 500));

防抖:延迟执行

const debounce = (func, delay) => {let timer;return (...args) => {clearTimeout(timer);timer = setTimeout(() => func(...args), delay);};
};document.getElementById("search").addEventListener("input", debounce(() => {console.log("用户正在输入...");
}, 300));

3. 异步加载资源

通过异步加载外部资源(如脚本或图片)提升页面加载速度。

示例:

<script src="large-script.js" async></script>
<script src="analytics.js" defer></script>
  • async:脚本异步加载并立即执行。
  • defer:脚本异步加载,但延迟到 DOM 完全解析后执行。

4. 使用 Web Workers

Web Workers 可将复杂计算移至后台线程,避免阻塞主线程。

示例:

// worker.js
self.onmessage = (event) => {const result = event.data * 2;self.postMessage(result);
};// 主线程
const worker = new Worker("worker.js");
worker.postMessage(5);
worker.onmessage = (event) => {console.log("计算结果:", event.data); // 输出:10
};

四、综合案例:简单搜索框

功能描述

  • 用户输入内容时,动态搜索匹配结果。
  • 防止高频搜索请求。

HTML

<input type="text" id="search" placeholder="搜索...">
<ul id="results"></ul>

JavaScript

const results = document.getElementById("results");
const debounce = (func, delay) => {let timer;return (...args) => {clearTimeout(timer);timer = setTimeout(() => func(...args), delay);};
};const search = async (query) => {const response = await fetch(`https://jsonplaceholder.typicode.com/users?name_like=${query}`);const users = await response.json();results.innerHTML = users.map(user => `<li>${user.name}</li>`).join("");
};document.getElementById("search").addEventListener("input", debounce((event) => {const query = event.target.value.trim();if (query) {search(query);} else {results.innerHTML = "";}
}, 300));

五、总结与下一步

通过本文,你学习了:

  1. 异步编程的多种方式(回调、Promise、async/await)。
  2. 面向对象编程的核心概念(类、继承、封装)。

能优化的常见技巧(节流、防抖、Web Workers)。

下一步

  • 学习如何使用 JavaScript 框架(如 React、Vue)构建复杂应用。
  • 探索服务端 JavaScript(Node.js)进行全栈开发。

掌握这些内容后,你将具备构建高效、健壮 Web 应用的能力!

相关文章:

JavaScript 高级教程:异步编程、面向对象与性能优化

在前两篇教程中&#xff0c;我们学习了 JavaScript 的基础和进阶内容。这篇文章将带领你进入更深层次&#xff0c;学习 JavaScript 的异步编程模型、面向对象编程&#xff08;OOP&#xff09;&#xff0c;以及性能优化的技巧。这些内容对于构建复杂、流畅的前端应用至关重要。 …...

qt QToolBox详解

1、概述 QToolBox是Qt框架中的一个控件&#xff0c;它提供了一个带标签页的容器&#xff0c;用户可以通过点击标签页标题来切换不同的页面。QToolBox类似于一个带有多页选项卡的控件&#xff0c;但每个“选项卡”都是一个完整的页面&#xff0c;而不仅仅是标签。这使得QToolBo…...

翁知宜荣获“易学名师”与“国学文化传承人”称号

在2024年10月19日举行的北京第六届国学文化传承峰会上&#xff0c;翁知宜老师以其在易学界的卓越成就和对国学文化的传承与发扬&#xff0c;荣获“易学名师”和“国学文化传承人”两项荣誉称号。 翁知宜老师在易经学术竞赛中荣获第一名&#xff0c;其深厚的易学造诣和对玄学学…...

20241128解决Ubuntu20.04安装libwxgtk3.0-dev异常的问题

20241128解决Ubuntu20.04安装libwxgtk3.0-dev异常的问题 2024/11/28 16:17 缘起&#xff1a;中科创达的高通CM6125开发板的Android10的编译环境需要。 安装异常&#xff1a;rootrootrootroot-X99-Turbo:~$ rootrootrootroot-X99-Turbo:~$ sudo apt-get install libwxgtk3.0-de…...

sql分类

SQL&#xff08;Structured Query Language&#xff09;是一种用于管理和操作关系数据库管理系统&#xff08;RDBMS&#xff09;的编程语言。SQL 可以分为几个主要类别&#xff0c;每个类别都有其特定的用途和功能。以下是 SQL 的主要分类&#xff1a; 1. 数据定义语言&#x…...

stm32里一个定时器可以提供多路信号吗?

在STM32中&#xff0c;一个定时器通常只能提供一组信号&#xff08;如输出PWM波形、定时中断等&#xff09;。但是&#xff0c;定时器的多个通道可以提供不同的信号。例如&#xff0c;STM32的定时器可以通过不同的输出通道产生多种PWM信号&#xff0c;每个通道可以配置为不同的…...

Java安全—原生反序列化重写方法链条分析触发类

前言 在Java安全中反序列化是一个非常重要点&#xff0c;有原生态的反序列化&#xff0c;还有一些特定漏洞情况下的。今天主要讲一下原生态的反序列化&#xff0c;这部分内容对于没Java基础的来说可能有点难&#xff0c;包括我。 序列化与反序列化 序列化&#xff1a;将内存…...

2023考研王道计算机408数据结构+操作系统+计算机组成原理+计算机网络

from: https://blog.csdn.net/weixin_46118419/article/details/125611299 写得很好&#xff01; 轻重缓急 2023考研计算机408【王-道计算机408】数据结构操作系统计算机组成原理计算机网络 网盘-链接&#xff1a;https://pan.baidu.com/s/13JraxUYwNVPeupdzprx5hA?pwd5h3d 提…...

YOLOv8-ultralytics-8.2.103部分代码阅读笔记-files.py

files.py ultralytics\utils\files.py 目录 files.py 1.所需的库和模块 2.class WorkingDirectory(contextlib.ContextDecorator): 3.def spaces_in_path(path): 4.def increment_path(path, exist_okFalse, sep"", mkdirFalse): 5.def file_age(path__fi…...

「Mac畅玩鸿蒙与硬件34」UI互动应用篇11 - 颜色选择器

本篇将带你实现一个颜色选择器应用。用户可以从预设颜色中选择&#xff0c;或者通过输入颜色代码自定义颜色来动态更改界面背景。该应用展示了如何结合用户输入、状态管理和界面动态更新的功能。 关键词 UI互动应用颜色选择器状态管理用户输入界面动态更新 一、功能说明 颜色…...

ELK(Elasticsearch + logstash + kibana + Filebeat + Kafka + Zookeeper)日志分析系统

文章目录 前言架构软件包下载 一、准备工作1. Linux 网络设置2. 配置hosts文件3. 配置免密登录4. 设置 NTP 时钟同步5. 关闭防火墙6. 关闭交换分区7. 调整内存映射区域数限制8. 调整文件、进程、内存资源限制 二、JDK 安装1. 解压软件2. 配置环境变量3. 验证软件 三、安装 Elas…...

07.ES11 08.ES12

7.1、Promise.allSettled 调用 allsettled 方法&#xff0c;返回的结果始终是成功的&#xff0c;返回的是promise结果值 <script>//声明两个promise对象const p1 new Promise((resolve, reject) > {setTimeout(() > {resolve("商品数据 - 1");}, 1000)…...

linux一键部署apache脚本

分享一下自己制作的一键部署apache脚本&#xff1a; 脚本已和当前文章绑定&#xff0c;请移步下载&#xff08;免费&#xff01;免费&#xff01;免费&#xff01;&#xff09; &#xff08;单纯的分享&#xff01;&#xff09; 步骤&#xff1a; 将文件/内容上传到终端中 …...

2022 年 6 月青少年软编等考 C 语言三级真题解析

目录 T1. 制作蛋糕思路分析T2. 找和最接近但不超过K的两个元素思路分析T3. 数根思路分析T4. 迷信的病人思路分析T5. 算 24思路分析T1. 制作蛋糕 小 A 擅长制作香蕉蛋糕和巧克力蛋糕。制作一个香蕉蛋糕需要 2 2 2 个单位的香蕉, 250 250 250 个单位的面粉, 75 75 75 个单位的…...

MySQL - Why Do We Need a Thread Pool? - mysql8.0

MySQL - Why Do We Need a Thread Pool? - mysql8.0 本文主要由于上次写的感觉又长又臭&#xff0c; 感觉学习方法有问题&#xff0c; 我们这次直接找来了 thread pool 的原文&#xff0c;一起来看看官方的开发者给出的blog – 感觉是个大神 但是好像不是最官方的 &#xff0c…...

Linux互斥量读写锁

一、互斥量 1.临界资源 同一时刻只允许一个进程/线程访问的共享资源&#xff08;比如文件、外设打印机&#xff09; 2.临界区 访问临界资源的代码 3.互斥机制 mutex互斥锁&#xff0c;用来避免临界资源的访问冲突&#xff0c;访问临界资源前申请互斥锁&#xff0c;访问完释放…...

网络安全之IP伪造

眼下非常多站点的涉及存在一些安全漏洞&#xff0c;黑客easy使用ip伪造、session劫持、xss攻击、session注入等手段危害站点安全。在纪录片《互联网之子》&#xff08;建议搞IT的都要看下&#xff09;中。亚伦斯沃茨&#xff08;真实人物&#xff0c;神一般的存在&#xff09;涉…...

ARM CCA机密计算安全模型之硬件强制安全

安全之安全(security)博客目录导读 [要求 R0004] Arm 强烈建议所有 CCA 实现都使用硬件强制的安全(CCA HES)。本文件其余部分假设系统启用了 CCA HES。 CCA HES 是一个可信子系统的租户——一个 CCA HES 主机(Host),见下图所示。它将以下监控安全域服务从应用处理元件(P…...

【论文笔记】A Token-level Contrastive Framework for Sign Language Translation

&#x1f34e;个人主页&#xff1a;小嗷犬的个人主页 &#x1f34a;个人网站&#xff1a;小嗷犬的技术小站 &#x1f96d;个人信条&#xff1a;为天地立心&#xff0c;为生民立命&#xff0c;为往圣继绝学&#xff0c;为万世开太平。 基本信息 标题: A Token-level Contrastiv…...

C#窗体简单登录

创建一个Windows登录程序&#xff0c;创建两个窗体&#xff0c;一个用来登录&#xff0c;一个为欢迎窗体&#xff0c;要求输入用户名和密码&#xff08;以个人的姓名和学号分别作为用户名和密码&#xff09;&#xff0c;点击【登录】按钮登录&#xff0c;登录成功后显示欢迎窗体…...

超短脉冲激光自聚焦效应

前言与目录 强激光引起自聚焦效应机理 超短脉冲激光在脆性材料内部加工时引起的自聚焦效应&#xff0c;这是一种非线性光学现象&#xff0c;主要涉及光学克尔效应和材料的非线性光学特性。 自聚焦效应可以产生局部的强光场&#xff0c;对材料产生非线性响应&#xff0c;可能…...

Redis相关知识总结(缓存雪崩,缓存穿透,缓存击穿,Redis实现分布式锁,如何保持数据库和缓存一致)

文章目录 1.什么是Redis&#xff1f;2.为什么要使用redis作为mysql的缓存&#xff1f;3.什么是缓存雪崩、缓存穿透、缓存击穿&#xff1f;3.1缓存雪崩3.1.1 大量缓存同时过期3.1.2 Redis宕机 3.2 缓存击穿3.3 缓存穿透3.4 总结 4. 数据库和缓存如何保持一致性5. Redis实现分布式…...

pam_env.so模块配置解析

在PAM&#xff08;Pluggable Authentication Modules&#xff09;配置中&#xff0c; /etc/pam.d/su 文件相关配置含义如下&#xff1a; 配置解析 auth required pam_env.so1. 字段分解 字段值说明模块类型auth认证类模块&#xff0c;负责验证用户身份&am…...

Qt Http Server模块功能及架构

Qt Http Server 是 Qt 6.0 中引入的一个新模块&#xff0c;它提供了一个轻量级的 HTTP 服务器实现&#xff0c;主要用于构建基于 HTTP 的应用程序和服务。 功能介绍&#xff1a; 主要功能 HTTP服务器功能&#xff1a; 支持 HTTP/1.1 协议 简单的请求/响应处理模型 支持 GET…...

Module Federation 和 Native Federation 的比较

前言 Module Federation 是 Webpack 5 引入的微前端架构方案&#xff0c;允许不同独立构建的应用在运行时动态共享模块。 Native Federation 是 Angular 官方基于 Module Federation 理念实现的专为 Angular 优化的微前端方案。 概念解析 Module Federation (模块联邦) Modul…...

Axios请求超时重发机制

Axios 超时重新请求实现方案 在 Axios 中实现超时重新请求可以通过以下几种方式&#xff1a; 1. 使用拦截器实现自动重试 import axios from axios;// 创建axios实例 const instance axios.create();// 设置超时时间 instance.defaults.timeout 5000;// 最大重试次数 cons…...

SpringCloudGateway 自定义局部过滤器

场景&#xff1a; 将所有请求转化为同一路径请求&#xff08;方便穿网配置&#xff09;在请求头内标识原来路径&#xff0c;然后在将请求分发给不同服务 AllToOneGatewayFilterFactory import lombok.Getter; import lombok.Setter; import lombok.extern.slf4j.Slf4j; impor…...

JVM暂停(Stop-The-World,STW)的原因分类及对应排查方案

JVM暂停(Stop-The-World,STW)的完整原因分类及对应排查方案,结合JVM运行机制和常见故障场景整理而成: 一、GC相关暂停​​ 1. ​​安全点(Safepoint)阻塞​​ ​​现象​​:JVM暂停但无GC日志,日志显示No GCs detected。​​原因​​:JVM等待所有线程进入安全点(如…...

Redis数据倾斜问题解决

Redis 数据倾斜问题解析与解决方案 什么是 Redis 数据倾斜 Redis 数据倾斜指的是在 Redis 集群中&#xff0c;部分节点存储的数据量或访问量远高于其他节点&#xff0c;导致这些节点负载过高&#xff0c;影响整体性能。 数据倾斜的主要表现 部分节点内存使用率远高于其他节…...

零基础在实践中学习网络安全-皮卡丘靶场(第九期-Unsafe Fileupload模块)(yakit方式)

本期内容并不是很难&#xff0c;相信大家会学的很愉快&#xff0c;当然对于有后端基础的朋友来说&#xff0c;本期内容更加容易了解&#xff0c;当然没有基础的也别担心&#xff0c;本期内容会详细解释有关内容 本期用到的软件&#xff1a;yakit&#xff08;因为经过之前好多期…...