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));
五、总结与下一步
通过本文,你学习了:
- 异步编程的多种方式(回调、Promise、async/await)。
- 面向对象编程的核心概念(类、继承、封装)。
- 性
能优化的常见技巧(节流、防抖、Web Workers)。
下一步:
- 学习如何使用 JavaScript 框架(如 React、Vue)构建复杂应用。
- 探索服务端 JavaScript(Node.js)进行全栈开发。
掌握这些内容后,你将具备构建高效、健壮 Web 应用的能力!
相关文章:
JavaScript 高级教程:异步编程、面向对象与性能优化
在前两篇教程中,我们学习了 JavaScript 的基础和进阶内容。这篇文章将带领你进入更深层次,学习 JavaScript 的异步编程模型、面向对象编程(OOP),以及性能优化的技巧。这些内容对于构建复杂、流畅的前端应用至关重要。 …...
qt QToolBox详解
1、概述 QToolBox是Qt框架中的一个控件,它提供了一个带标签页的容器,用户可以通过点击标签页标题来切换不同的页面。QToolBox类似于一个带有多页选项卡的控件,但每个“选项卡”都是一个完整的页面,而不仅仅是标签。这使得QToolBo…...
翁知宜荣获“易学名师”与“国学文化传承人”称号
在2024年10月19日举行的北京第六届国学文化传承峰会上,翁知宜老师以其在易学界的卓越成就和对国学文化的传承与发扬,荣获“易学名师”和“国学文化传承人”两项荣誉称号。 翁知宜老师在易经学术竞赛中荣获第一名,其深厚的易学造诣和对玄学学…...
20241128解决Ubuntu20.04安装libwxgtk3.0-dev异常的问题
20241128解决Ubuntu20.04安装libwxgtk3.0-dev异常的问题 2024/11/28 16:17 缘起:中科创达的高通CM6125开发板的Android10的编译环境需要。 安装异常:rootrootrootroot-X99-Turbo:~$ rootrootrootroot-X99-Turbo:~$ sudo apt-get install libwxgtk3.0-de…...
sql分类
SQL(Structured Query Language)是一种用于管理和操作关系数据库管理系统(RDBMS)的编程语言。SQL 可以分为几个主要类别,每个类别都有其特定的用途和功能。以下是 SQL 的主要分类: 1. 数据定义语言&#x…...
stm32里一个定时器可以提供多路信号吗?
在STM32中,一个定时器通常只能提供一组信号(如输出PWM波形、定时中断等)。但是,定时器的多个通道可以提供不同的信号。例如,STM32的定时器可以通过不同的输出通道产生多种PWM信号,每个通道可以配置为不同的…...
Java安全—原生反序列化重写方法链条分析触发类
前言 在Java安全中反序列化是一个非常重要点,有原生态的反序列化,还有一些特定漏洞情况下的。今天主要讲一下原生态的反序列化,这部分内容对于没Java基础的来说可能有点难,包括我。 序列化与反序列化 序列化:将内存…...
2023考研王道计算机408数据结构+操作系统+计算机组成原理+计算机网络
from: https://blog.csdn.net/weixin_46118419/article/details/125611299 写得很好! 轻重缓急 2023考研计算机408【王-道计算机408】数据结构操作系统计算机组成原理计算机网络 网盘-链接: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 - 颜色选择器
本篇将带你实现一个颜色选择器应用。用户可以从预设颜色中选择,或者通过输入颜色代码自定义颜色来动态更改界面背景。该应用展示了如何结合用户输入、状态管理和界面动态更新的功能。 关键词 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 方法,返回的结果始终是成功的,返回的是promise结果值 <script>//声明两个promise对象const p1 new Promise((resolve, reject) > {setTimeout(() > {resolve("商品数据 - 1");}, 1000)…...
linux一键部署apache脚本
分享一下自己制作的一键部署apache脚本: 脚本已和当前文章绑定,请移步下载(免费!免费!免费!) (单纯的分享!) 步骤: 将文件/内容上传到终端中 …...
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 本文主要由于上次写的感觉又长又臭, 感觉学习方法有问题, 我们这次直接找来了 thread pool 的原文,一起来看看官方的开发者给出的blog – 感觉是个大神 但是好像不是最官方的 ,…...
Linux互斥量读写锁
一、互斥量 1.临界资源 同一时刻只允许一个进程/线程访问的共享资源(比如文件、外设打印机) 2.临界区 访问临界资源的代码 3.互斥机制 mutex互斥锁,用来避免临界资源的访问冲突,访问临界资源前申请互斥锁,访问完释放…...
网络安全之IP伪造
眼下非常多站点的涉及存在一些安全漏洞,黑客easy使用ip伪造、session劫持、xss攻击、session注入等手段危害站点安全。在纪录片《互联网之子》(建议搞IT的都要看下)中。亚伦斯沃茨(真实人物,神一般的存在)涉…...
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
🍎个人主页:小嗷犬的个人主页 🍊个人网站:小嗷犬的技术小站 🥭个人信条:为天地立心,为生民立命,为往圣继绝学,为万世开太平。 基本信息 标题: A Token-level Contrastiv…...
C#窗体简单登录
创建一个Windows登录程序,创建两个窗体,一个用来登录,一个为欢迎窗体,要求输入用户名和密码(以个人的姓名和学号分别作为用户名和密码),点击【登录】按钮登录,登录成功后显示欢迎窗体…...
基于ZYNQ-7000系列的FPGA学习笔记3——开发环境搭建点亮一个LED
基于ZYNQ-7000系列的FPGA学习笔记3——开发环境搭建&点亮一个LED 1. 搭建开发环境2. FPGA的开发流程3. 点亮一个LED3.1 实验要求3.2 新建工程3.3 原理图3.4 绘制系统框图3.5 绘制波形图3.6 编写RTL代码3.7 软件仿真3.8 Vivado软件创建工程3.9 分析与综合3.10 设计实现 在上…...
队列-链式描述(C++)
定义 使用链表描述队列时,通常包含以下几个基本要素: 队头指针(Front Pointer):指向队列中第一个(即最早进入队列的)元素的节点。队尾指针(Rear Pointer):指…...
Kali Linux使用Netdiscover工具的详细教程
Kali Linux使用Netdiscover工具的详细教程 引言 在网络安全和渗透测试的过程中,网络发现是一个至关重要的步骤。Netdiscover是Kali Linux中一个非常实用的网络发现工具,它可以帮助用户快速识别局域网中的活动设备。本文将详细介绍如何使用Netdiscover工…...
arkTS:使用ArkUI实现用户信息的持久化管理与自动填充(PersistentStorage)
arkUI:使用ArkUI实现用户信息的持久化管理与自动填充(PersistentStorage) 1 主要内容说明2 例子2.1 登录页2.1.1登陆页的相关说明2.1.1.1 持久化存储的初始化2.1.1.2 输入框2.1.1.3 记住密码选项2.1.1.4 登录按钮的逻辑2.1.1.5 注册跳转 2.1.…...
IntelliJ+SpringBoot项目实战(二十)--基于SpringSecurity实现Oauth2服务端和客户端
在前面的帖子中介绍了SpringSecurityJWT实现了认证和授权的功能。因为基于Oauth2的统一认证在项目需求中越来越多,所以有必要将OAuth2的解决方案也整合进来,这样我们的产品既可以作为一个业务系统,也可以作为一个独立的统一认证服务器。下面详…...
如何实现剪裁功能
文章目录 1 概念介绍2 使用方法2.1 ClipOval2.2 ClipRRect3 示例代码我们在上一章回中介绍了AspectRatio Widget相关的内容,本章回中将介绍剪裁类组件(Clip).闲话休提,让我们一起Talk Flutter吧。 1 概念介绍 我们在这里说的剪裁类组件主要是指对子组件进行剪裁操作,常用的…...
LeetCode 动态规划 爬楼梯
爬楼梯 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢? 示例 1: 输入:n 2 输出:2 解释:有两种方法可以爬到楼顶。 1 阶 1 阶 2 阶 示例 2ÿ…...
Java 工厂模式:深度解析与应用指南
在 Java 编程的广袤天地里,设计模式宛如璀璨星辰,照亮了开发者构建高效、灵活且可维护软件系统的道路。其中,工厂模式作为创建型设计模式的关键成员,在对象创建环节扮演着举足轻重的角色,极大地增强了代码的适应性与扩…...
HTML5系列(5)-- SVG 集成详解
前端技术探索系列:HTML5 SVG 集成详解 🎨 开篇寄语 👋 前端开发者们, 在前五篇文章中,我们探讨了 HTML5 的多个特性。今天,让我们深入了解 SVG 的魅力,看看如何创建可缩放的矢量图形。 一、…...
深度学习常见数据集处理方法
1、数据集格式转换(json转txt) import json import os 任务:实例分割,labelme的json文件, 转txt文件 Ultralytics YOLO format <class-index> <x1> <y1> <x2> <y2> ... <xn> <yn> # 类…...
wordpress 局域网/公司网站建设平台
第四章:Python科学计算、数据分析、图表可视化库--Scipy04-Python科学计算、数据分析、图表可视化库1 Scipy入门1.1 Scipy简介Scipy是世界上著名的Python开源科学计算库,建立在Numpy之上。在NumPy库的基础上增加了众多的数学、科学以及工程计算中常用的库…...
免费网站app软件/七台河网站seo
本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理 本文章来自腾讯云 作者:python学习教程 想要学习Python?有问题得不到第一时间解决?来看看这里“1039649593”满足你的…...
东阿做网站推广/西安抖音seo
我们在使用guitar pro进行吉他自学练习时,经常会用到节拍器,接下来,我们先来了解一下什么是节拍器。节拍器是一种能够在各种速度中发出一种稳定节拍的机械、电动或电子装置。大部分人在学习吉他的阶段,弹奏吉他时的节拍都有问题&a…...
做c 题的网站/aso优化技巧大aso技巧
先来看一个问题 解决线程安全问题有两种方式: 方式1: synchronized 方式2:可重入锁 多读多写:读写锁 多读一写:volate 【一】隐式锁 和 显式锁 一、隐式锁 只有synchronized 详见:synchronized 篇 二、显式锁 1、定义ÿ…...
许昌大成建设集团网站/外包公司
“定位”就是测定位置。“卫星定位系统”这个词听上去给人感觉很生硬也很复杂,换成GPS(Global Positioning System,全球卫星定位系统)这个说法,想必大家就不陌生了。GPS 传感器在车载导航系统和智能手机上也有所应用&a…...
上海做网站公/seo教程网站优化推广排名
windows:CtrlAltL MAC:ComOptionL...