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 应用的能力!

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

uniapp手机端一些坑记录

关于 z-paging-x 组件&#xff0c;在ios上有时候通过弹窗去粗发它reload时会触发闪退&#xff0c;可能是弹框插入进去导致的DOM 元素已经被移除或者不可用&#xff0c;解决办法是加上他自带属性 :showRefresherWhenReload"true" 加上showRefresherWhe…

数据集-目标检测系列- 海边漫步锻炼人检测数据集 person >> DataBall

数据集-目标检测系列- 海边漫步锻炼人检测数据集 person >> DataBall DataBall 助力快速掌握数据集的信息和使用方式&#xff0c;会员享有 百种数据集&#xff0c;持续增加中。 需要更多数据资源和技术解决方案&#xff0c;知识星球&#xff1a; “DataBall - X 数据球…

NLP信息抽取大总结:三大任务(带Prompt模板)

信息抽取大总结 1.NLP的信息抽取的本质&#xff1f;2.信息抽取三大任务&#xff1f;3.开放域VS限定域4.信息抽取三大范式&#xff1f;范式一&#xff1a;基于自定义规则抽取&#xff08;2018年前&#xff09;范式二&#xff1a;基于Bert下游任务建模抽取&#xff08;2018年后&a…

手机中的核心SOC是什么?

大家好&#xff0c;我是山羊君Goat。 常常听说CPU&#xff0c;中央处理器等等的&#xff0c;它是一个电脑或单片机系统的核心&#xff0c;但是对于SOC可能相比于CPU了解的人没有那么广泛。 所以SOC是什么&#xff1f; SOC全称是System on Chip&#xff0c;就是片上系统&#…

网络--socket编程--基础

1、网络字节序 已知:内存中的很多数据都有大小端之分,在网络这,网络数据流也是有大小端之分的。 TCP/IP协议规定:网络数据流采用大端字节序(即低地址处放高位字节)。 因此,小端机器发送网络数据流之前,必须转为大端(一般的机器会自动转换): 在网络-本地字节序转换…

Transformers在计算机视觉领域中的应用【第1篇:ViT——Transformer杀入CV界之开山之作】

目录 1 模型结构2 模型的前向过程3 思考4 结论 论文&#xff1a; AN IMAGE IS WORTH 16X16 WORDS: TRANSFORMERS FOR IMAGE RECOGNITION AT SCALE 代码&#xff1a;https://github.com/google-research/vision_transformer Huggingface&#xff1a;https://github.com/huggingf…

<数据集>路面坑洼识别数据集<目标检测>

数据集格式&#xff1a;VOCYOLO格式 图片数量&#xff1a;665张 标注数量(xml文件个数)&#xff1a;665 标注数量(txt文件个数)&#xff1a;665 标注类别数&#xff1a;1 标注类别名称&#xff1a;[pothole] 序号类别名称图片数框数1pothole6651740 使用标注工具&#x…

IDEA的简易安装思路

IDEA(本身就是Java开发的)&#xff1a;是目前为止开发Java效率最高的工具&#xff0c;但正版收费……&#xff08;eclipse的话不好说&#xff0c;反正还是随主流吧&#xff09; 使用IDEA的前提&#xff1a;必须先安装JDK【否则直接使用IDEA工具来运行程序是无效的&#xff0c;它…

PySide6 QSS(Qt Style Sheets) Reference: PySide6 QSS参考指南

Qt官网参考资料&#xff1a; QSS介绍&#xff1a; Styling the Widgets Application - Qt for Pythonhttps://doc.qt.io/qtforpython-6/tutorials/basictutorial/widgetstyling.html#tutorial-widgetstyling QSS 参考手册&#xff1a; Qt Style Sheets Reference | Qt Widge…

07.ES11 08.ES12

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

qt QGraphicsRotation详解

1、概述 QGraphicsRotation 是 Qt 框架中 QGraphicsTransform 的一个子类&#xff0c;它专门用于处理图形项的旋转变换。通过 QGraphicsRotation&#xff0c;你可以对 QGraphicsItem&#xff08;如形状、图片等&#xff09;进行旋转操作&#xff0c;从而创建动态和吸引人的视觉…

【概率论】分布函数的定义与应用:从直观到数学形式

目录 1. 分布函数的直观引入1.1 从一个例子出发 1.2 累积分布与分布函数2. 分布函数的定义2.1 数学定义2.2 分布函数的图像 3. 分布函数的性质4. 离散型与连续型分布函数4.1 离散型分布函数4.2 连续型分布函数 5. 应用与计算5.1 由分布函数计算概率5.2 分布函数求导 6. 总结与展…

Unity Plane API解释

构造函数解释&#xff0c;d的解释为&#xff1a;距离是沿着平面法线从平面到原点的距离。注意&#xff0c;这意味着为正值的distance值将导致平面朝向原点。负的距离值会导致平面朝向远离原点。 试验&#xff1a; GetSide方法检测点是否位于平面的正向侧&#xff0c;结果显示…

文本内容处理命令和正则表达式

文本内容处理命令 grep 用来过滤文本内容&#xff0c;以匹配要查询的结果。 -m 数字 匹配几次后停止&#xff1a; grep -m 1 /root/etc/passwd #查找包含root的行 -v 取反 -i 忽略字符的大小写&#xff0c;默认的&#xff0c;可以不加 -n 显示匹配的行号 -c 统计匹配的…

大数据治理:解锁数据价值,引领未来创新

目录 引言 一、大数据治理的定义 二、大数据治理的重要性 三、大数据治理的核心组件 四、大数据治理的实践案例 1. 数据标准化 2. 数据质量管理 案例一&#xff1a;医疗行业的大数据治理——智能医疗助手守护健康 引言 在数字化时代&#xff0c;数据已成为企业最宝贵的…

如何在 Ubuntu 18.04 上设置 Apache 虚拟主机

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。 简介 Apache Web 服务器是一种流行的在互联网上提供网站服务的方法。截至2019年&#xff0c;据估计&#xff0c;它为所有活跃网站的29%…

【Leetcode Top 100】142. 环形链表 II

问题背景 给定一个链表的头节点 h e a d head head&#xff0c;返回链表开始入环的第一个节点。 如果链表无环&#xff0c;则返回 n u l l null null。 如果链表中有某个节点&#xff0c;可以通过连续跟踪 n e x t next next 指针再次到达&#xff0c;则链表中存在环。 为了…

「网络安全入门」什么是网络安全

如今&#xff0c;组织的信息系统和数据面临着许多威胁。而人们了解网络安全的所有基本要素是应对这些威胁的第一步。 网络安全是确保信息完整性、机密性和可用性(ICA)的做法。它代表了应对硬盘故障、断电事故&#xff0c;以及来自黑客或竞争对手攻击等防御和恢复能力。而后者包…

通讯专题4.1——CAN通信之计算机网络与现场总线

从通讯专题4开始&#xff0c;来学习CAN总线的内容。 为了更好的学习CAN&#xff0c;先从计算机网络与现场总线开始了解。 1 计算机网络体系的结构 在我们生活当中&#xff0c;有许多的网络&#xff0c;如交通网&#xff08;铁路、公路等&#xff09;、通信网&#xff08;电信、…

深度学习模型:LSTM (Long Short-Term Memory) - 长短时记忆网络详解

一、引言 在深度学习领域&#xff0c;循环神经网络&#xff08;RNN&#xff09;在处理序列数据方面具有独特的优势&#xff0c;例如语音识别、自然语言处理等任务。然而&#xff0c;传统的 RNN 在处理长序列数据时面临着严重的梯度消失问题&#xff0c;这使得网络难以学习到长…