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.rhkb.cn/news/482108.html

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

相关文章

给定一个整数可能为正,0,负数,统计这个数据的位数.

题目描述 给定一个整数可能为正,0,负数,统计这个数据的位数. 例如1234567输出7位; -12345678输出8位;0输出1位 代码实现 int main() { long long m; long long n; scanf("%lld",&n); mn; int count0;//位数 do { count; n/10;//舍弃个位 }while(n!0); printf(&…

Linux:文件系统inode

早期&#xff0c;存储文件的设备是磁盘&#xff08;当下的市场几乎都是SSD&#xff09;&#xff0c;但大家习惯的把它们都称为磁盘&#xff0c;磁盘是用来表示区分内存的存储设备。而在操作系统看来&#xff0c;这个存储设备的结构就是一个线性结构&#xff0c;这一点很重要。 …

C++STL之vector(超详细)

CSTL之vector 1.vector基本介绍2.vector重要接口2.1.构造函数2.2.迭代器2.3.空间2.3.1.resize2.3.2.capacity 2.4.增删查找 3.迭代器失效4.迭代器分类 &#x1f31f;&#x1f31f;hello&#xff0c;各位读者大大们你们好呀&#x1f31f;&#x1f31f; &#x1f680;&#x1f68…

深入浅出机器学习中的梯度下降算法

大家好&#xff0c;在机器学习中&#xff0c;梯度下降算法&#xff08;Gradient Descent&#xff09;是一个重要的概念。它是一种优化算法&#xff0c;用于最小化目标函数&#xff0c;通常是损失函数。梯度下降可以帮助找到一个模型最优的参数&#xff0c;使得模型的预测更加准…

树莓派5+文心一言 -> 智能音箱

一、简介 效果&#xff1a;运行起来后&#xff0c;可以连续对话 硬件&#xff1a;树莓派5、麦克风、音箱&#xff0c;成本500-1000 软件&#xff1a;snowboy作为唤醒词、百度语音作为语音识别、brain作为指令匹配、百度文心一言作为对话模块、微软的edge-tts语音合成... 二…

Springboot——SseEmitter流式输出

文章目录 前言SseEmitter 简介测试demo注意点异常一 ResponseBodyEmitter is already set complete 前言 最近做AI类的开发&#xff0c;看到各大AI模型的输出方式都是采取的一种EventStream的方式实现。 不是通常的等接口处理完成后&#xff0c;一次性返回。 而是片段式的处理…

5G学习笔记之随机接入

目录 1. 概述 2. MSG1 2.1 选择SSB 2.2 选择Preamble Index 2.3 选择发送Preamble的时频资源 2.4 确定RA-RNTI 2.5 确定发送功率 3. MSG2 4. MSG3 5. MSG4 6. 其它 6.1 切换中的随机接入 6.2 SI请求的随机接入 6.3 通过PDCCH order重新建立同步 1. 概述 随机接入…

【Linux-多线程】重谈地址空间+内存管理方式

一、背景知识 a.重谈地址空间 我们之前已经说过&#xff0c;CPU内部见的地址&#xff0c;以及我们打印出来的地址都是虚拟地址&#xff1b;物理内存加载到CPU&#xff0c;CPU内执行进程创建内核数据结构&#xff0c;页表等&#xff0c;通过页表映射到物理磁盘上&#xff1b;也…

Spark Optimization —— Reducing Shuffle

Spark Optimization : Reducing Shuffle “Shuffling is the only thing which Nature cannot undo.” — Arthur Eddington Shuffle Shuffle Shuffle I used to see people playing cards and using the word “Shuffle” even before I knew how to play it. Shuffling in c…

Elasticsearch——Java API 操作

Elasticsearch 软件是由Java语言开发的,所以也可以通过JavaAPI的方式对 Elasticsearch服务进行访问。 创建 Maven 项目 我们在 IDEA 开发工具中创建 Maven 项目(模块也可)ES。并修改pom文件&#xff0c;增加Maven依赖关系。 #直接复制在pom文件的<dependencies></de…

量化的8位LLM训练和推理使用bitsandbytes在AMD GPUs上

Quantized 8-bit LLM training and inference using bitsandbytes on AMD GPUs — ROCm Blogs 在这篇博客文章中&#xff0c;我们将介绍bitsandbytes的8位表示方式。正如你将看到的&#xff0c;bitsandbytes的8位表示方式显著地减少了微调和推理大语言模型&#xff08;LLMs&…

自回归(Autoregressive)模型概述

自回归&#xff08;Autoregressive&#xff09;模型概述 自回归&#xff08;Autoregressive&#xff0c;简称AR&#xff09;模型是一类基于“历史数据”来预测未来数据的模型。其核心思想是模型的输出不仅依赖于当前输入&#xff0c;还依赖于先前的输出。自回归模型通常用于时…

Win11电脑亮度无法调节以及夜间模式点击没有用失效解决方法

一、问题 最近&#xff0c;突然感觉屏幕亮度十分刺眼&#xff0c;想调整为夜间模式&#xff0c;发现点了夜间模式根本没用&#xff0c;亮度也是变成了灰色。 明明前几天还能调节的&#xff0c;这实在是太难受了&#xff01; 二、原因 这是远程控制软件向日葵的问题 在向日葵…

Linux笔记---进程:进程终止

1. 进程终止概念与分类 进程终止是指一个正在运行的进程结束其执行的操作。以下是一些常见的导致进程终止的情况&#xff1a; 一、正常终止 完成任务当进程完成了它被设计要执行的任务后&#xff0c;就会正常终止。收到特定信号在操作系统中&#xff0c;进程可能会收到来自操作…

【工具推荐】dnsx——一个快速、多用途的 DNS 查询工具

basic/基本使用方式 echo baidu.com | dnsx -recon # 查询域名所有记录echo baidu.com | dnsx -a -resp # 查询域名的a记录echo baidu.com | dnsx -txt -resp # 查询域名的TXT记录echo ip | dnsx -ptr -resp # ip反查域名 A记录查询 TXT记录查询 ip反查域名 help/帮助信息 输…

【树莓派5】移动热点获取树莓派IP并初次登录SSH

本篇文章包含的内容 1 打开系统热点2 烧录系统设置3 配置 MobaXterm4 初次启动树莓派配置选项4.1 换源4.2 更新软件包4.3 安装vim编辑器4.4 更改CPU FAN温度转速 Windows版本&#xff1a;Windows11 24H2树莓派&#xff1a;树莓派5&#xff0c;Raspberry Pi 5SSH软件&#xff1a…

【Git系列】Git 提交历史分析:深入理解`git log`命令

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

第144场双周赛:移除石头游戏、两个字符串得切换距离、零数组变换 Ⅲ、最多可收集的水果数目

Q1、[简单] 移除石头游戏 1、题目描述 Alice 和 Bob 在玩一个游戏&#xff0c;他们俩轮流从一堆石头中移除石头&#xff0c;Alice 先进行操作。 Alice 在第一次操作中移除 恰好 10 个石头。接下来的每次操作中&#xff0c;每位玩家移除的石头数 恰好 为另一位玩家上一次操作…

Python parsel库学习总结

parsel库是Python中用于解析HTML文件的库&#xff0c;其能通过CSS选择器、xpath、正则表达式来定位html中的元素。 通过css选择器定位元素 from parsel import Selectorhtml """ <html><head><a class"option1">这是一个伪html片…

【HarmonyOS学习日志(11)】计算机网络之概念,组成和功能

文章目录 计算机网络概念计算机网络&#xff0c;互连网与互联网的区别计算机网络互连网互联网&#xff08;因特网&#xff0c;Internet&#xff09; 计算机网络的组成和功能计算机网络的组成从组成部分看从工作方式看从逻辑功能看 计算机网络的功能数据通信资源共享分布式处理提…