JavaScript 中的回调函数(callback)
JavaScript 中的回调函数(callback)
JavaScript 中的回调函数(callback)是一个传递给另一个函数作为参数的函数,并且这个传递的函数可以在其他函数内部被调用执行。回调函数是异步编程的一个核心概念,特别是在处理事件处理、服务器请求或者在操作完成后需要运行的代码时非常有用。
回调函数的工作方式
- 定义一个函数,然后将它作为参数传递给另一个函数。
- 在这个接收函数中,你可以根据需要调用传递进来的回调函数。
- 回调函数执行的具体时机可以根据外部函数的逻辑来确定,它可以在外部函数开始时、结束时或者在处理某些特定任务时执行。
假设我们有一个处理文件下载的函数,我们希望在下载完成后执行一些操作,这些操作可以通过回调函数来定义:
function download(url, callback) {setTimeout(() => {// 假设这里是下载文件的逻辑console.log(`Downloading ${url} ...`);// 下载完成后调用回调函数callback(url);}, 2000); // 模拟下载需要2秒钟
}function processFile(url) {console.log(`Processing ${url}`);
}// 调用 download 函数,并将 processFile 函数作为回调传递
download("http://example.com/file.mp3", processFile);
在这个例子中,download 函数模拟了文件下载的过程,并接受一个 callback 参数。当下载(模拟的 setTimeout)完成后,它会调用 processFile 回调函数。
回调函数的优点和缺点
-
优点:
- 简单易懂,容易实现。
- 支持在操作完成后执行代码,而无需阻塞程序的其他部分。
-
缺点:
- 深层次的嵌套回调(俗称“回调地狱”)会使代码难以阅读和维护。
- 错误处理麻烦,每个回调函数都需要单独处理错误。
随着 JavaScript 的发展,Promise 和 async/await 等现代特性为异步编程提供了更优雅的解决方案,它们可以帮助避免回调地狱的问题,并提供更清晰的错误处理机制。
回调地狱(Callback Hell)
在 JavaScript 中,“回调地狱”(Callback Hell),也称为“金字塔厄运”(Pyramid of Doom),是指多层嵌套的回调函数导致代码结构复杂、难以维护和理解的情况。这种模式在 JavaScript 异步编程中常见,尤其是在处理多个依赖于先前操作结果的异步任务时。
回调地狱的特征
- 多层嵌套的回调函数,使代码向右侧不断延伸。
- 错误处理复杂,每个回调可能需要单独的错误处理逻辑。
- 代码可读性和可维护性差。
以下是一个回调地狱的例子,演示了在读取文件、解析数据和存储结果时如何逐层嵌套回调:
const fs = require('fs');fs.readFile('data.txt', 'utf-8', function(err, data) {if (err) {console.error("Error reading file!");return;}parseData(data, function(err, parsed) {if (err) {console.error("Error parsing data!");return;}fs.writeFile('output.txt', parsed, function(err) {if (err) {console.error("Error writing file!");return;}console.log("File written successfully!");});});
});
用 Promise 解决回调地狱
- 模块化:将每个回调分解为独立的函数,减少嵌套。
- 使用 Promise:Promise 提供了更好的错误处理和链式调用方法,可以用
.then()和.catch()方法来组织代码。 - Async/Await:使用 ES2017 引入的 async 和 await 关键字可以以同步的方式写异步代码,使代码更加清晰。
使用 Promise 来避免回调地狱:
const fs = require('fs').promises;function parseData(data) {return new Promise((resolve, reject) => {try {const parsed = JSON.parse(data);resolve(parsed);} catch (e) {reject("Error parsing data!");}});
}async function processFile() {try {const data = await fs.readFile('data.txt', 'utf-8');const parsed = await parseData(data);await fs.writeFile('output.txt', JSON.stringify(parsed));console.log("File written successfully!");} catch (err) {console.error(err);}
}processFile();
这样,我们通过使用 Promise 和 async/await,有效地将多层嵌套的回调转换成了更易读和维护的代码结构。这也展示了现代 JavaScript 异步编程的一个重要进步。
相关文章:
JavaScript 中的回调函数(callback)
JavaScript 中的回调函数(callback) JavaScript 中的回调函数(callback)是一个传递给另一个函数作为参数的函数,并且这个传递的函数可以在其他函数内部被调用执行。回调函数是异步编程的一个核心概念,特别…...
计算机毕业设计hadoop+spark+hive漫画推荐系统 动漫视频推荐系统 漫画分析可视化大屏 漫画爬虫 漫画推荐系统 漫画爬虫 知识图谱 大数据
HadoopSparkHive漫画推荐系统详细开题报告 一、引言 随着互联网技术的飞速发展,动漫和漫画产业的数据量急剧增长。用户面临着海量漫画作品的选择难题,如何从这些数据中高效地提取有价值的信息,为用户推荐符合其喜好的漫画作品,成…...
解决pycharm日志总是弹出“无法运行Git,未安装Git”的问题
需求分析 我电脑中安装了git,但是打开pycharm,右下角总是弹出 无法运行Git,未安装Git的日志。 解决方法 首先打开pycharm,按照以下路径,依次点击。 file -----settings-----version control -----Git----Git path(选择自己下载…...
threejs 节点材质系统 绑定attribute
新的 节点材质系统 绑定属性及使用 非常方便 不必重复声明 以instances为例 import {instancedBufferAttribute,instancedDynamicBufferAttribute,} from "three/tsl";声明一个 InstancedBufferAttribute 使用 instancedBufferAttribute包装后就可以在shader中直接使…...
Rabbitmq的几种工作模式
工具类 public class RabbitMQConnection {public static Connection getConnection() throws Exception{//1.创建connectionFactoryConnectionFactory connectionFactory new ConnectionFactory();//2.配置HostconnectionFactory.setHost("127.0.0.1");//3.设置Po…...
如何在 Debian 上安装运行极狐GitLab Runner?【二】
极狐GitLab 是 GitLab 在中国的发行版,专门面向中国程序员和企业提供企业级一体化 DevOps 平台,用来帮助用户实现需求管理、源代码托管、CI/CD、安全合规,而且所有的操作都是在一个平台上进行,省事省心省钱。可以一键安装极狐GitL…...
简单的docker学习 第13章 CI/CD与Jenkins(下)
第13章 CI/CD 与 Jenkins 13.13 自由风格的 CI 操作(最终架构) 前面的架构存在的问题是,若有多个目标服务器都需要使用该镜像,那么每个目标服务器都需要在本地构建镜像,形成系统资源浪费。若能够在 Jenkins 中将镜像相撞构建好并推送到 Har…...
基于STM32设计的智能鱼缸_带鱼儿数量视觉识别(华为云IOT)(202)
文章目录 一、前言1.1 项目介绍【1】项目功能介绍【2】设计实现的功能【3】项目硬件模块组成1.2 设计思路【1】整体设计思路【2】ESP8266工作模式配置【3】自动换水原理1.3 项目开发背景【1】选题的意义【2】可行性分析【3】参考文献1.4 开发工具的选择【1】设备端开发【2】上位…...
立体连接模式下的传播与沟通:AI智能名片小程序的创新应用与深度剖析
摘要:在数字化浪潮的推动下,信息传播与沟通方式正经历着前所未有的变革。立体连接模式,作为这一变革的重要产物,通过整合物理空间、虚拟网络空间与社群心理空间的三维联动,实现了信息的深度传播与高效互动。AI智能名片…...
基于Python的Scrapy爬虫的个性化书籍推荐系统【Django框架、超详细系统设计原型】
文章目录 有需要本项目的代码或文档以及全部资源,或者部署调试可以私信博主项目介绍系统分析系统设计展示总结 有需要本项目的代码或文档以及全部资源,或者部署调试可以私信博主 项目介绍 近年来,随着互联网的蓬勃发展,企事业单…...
二叉树bst
二叉搜索树的中序遍历结果有序 ,二叉搜索树性质,左小右大,二叉搜索树中序遍历的结果应该是从小到大的。 题目描述二叉树是从上到下,从左到右描述,并非前中后序中的一种。 99. 恢复二叉搜索树 class Solution:first …...
elasticsearch的使用(二)
DSL查询 Elasticsearch的查询可以分为两大类: 叶子查询(Leaf query clauses):一般是在特定的字段里查询特定值,属于简单查询,很少单独使用。 复合查询(Compound query clauses)&am…...
YOLOv8由pt文件中读取模型信息
Pytorch的pt模型文件中保存了许多模型信息,如模型结构、模型参数、任务类型、批次、数据集等 在先前的YOLOv8实验中,博主发现YOLOv8在预测时并不需要指定任务类型,因为这些信息便保存在pt模型中,那么,今天我们便来看看…...
js遍历效率
1w条数据,遍历效率 1、for 15s let t(new Date()).getTime()let a[]for(var i 0; i < 100000; i){a.push({id:i,val:i})}let ts[]for(var i 0; i < a.length; i){if(a[i].val!2 && a[i].val!4 && a[i].val!8){ts.push(a[i])}}let c(new D…...
QModbus例程分析
由于有一个Modebus上位机的需要,分析一下QModbus Slave的源代码,方便后面的开发。 什么是Modbus Modbus是一种常用的串行通信协议,被广泛应用于工业自动化领域。它最初由Modicon(目前属于施耐德电气公司)于1979年开发…...
Vue万字学习笔记(入门1)
目录 简介 Vue是什么 渐进式框架 单文件组件 API 风格 选项式 API (Options API) 组合式 API (Composition API) 创建一个 Vue 应用 挂载应用 DOM 中的根组件模板 应用配置 多个应用实例 模板语法 文本插值 原始 HTML Attribute 绑定 简写…...
Cesium手动建模模型用Cesiumlab转3D Tiles模型位置不对,调整模型位置至指定经纬度
Cesium加载3Dtiles模型的平移和旋转_3dtiles先旋转再平移示例-CSDN博客 Cesium 平移cesiumlab生产的3Dtiles切片模型到目标经纬度-CSDN博客 【ArcGISCityEngine】自行制作Lod1城市大尺度白膜数据_cityengine 生成指定坐标集指定区域的白模-CSDN博客 以上次ArcGISCityEngine制…...
学习C语言第23天(程序环境和预处理)
1. 程序的翻译环境和执行环境 在ANSIC的任何一种实现中,存在两个不同的环境 第1种是翻译环境,在这个环境中源代码被转换为可执行的机器指令。 第2种是执行环境,它用于实际执行代码。 2. 详解编译链接 2.1 翻译环境 每个源文件单独经过编…...
Ubuntu22.04安装
使用Vmware安装好后 首先执行下面命令,不然每次打开终端会出现To run a command as administrator (user root)… touch ~/.sudo_as_admin_successful换源 参考 sudo cp /etc/apt/sources.list /etc/apt/sources.list.baksudo gedit /etc/apt/sources.list清空…...
从入门到自动化:一篇文章掌握Python的80%
Python作为一种高级编程语言,以其简洁明了的语法和强大的功能性,在全球编程社区内享有极高的声誉。本文将带领你从Python的基础语法入手,介绍其常用库的应用,以及如何将Python用于数据分析、网络爬虫和简单的自动化任务࿰…...
Harness 中的事务边界定义:微事务与补偿
Harness 中的事务边界定义:微事务与补偿 引言 核心概念铺垫 在开始本文的核心内容——Harness 中的事务边界定义与微事务/补偿实践体系——之前,我们需要先锚定一组贯穿全文的、与 CI/CD 交付流水线强绑定的专属术语与业务通用术语的融合定义: 交付事务(Delivery Transac…...
seo中文网站如何应对算法更新
SEO中文网站如何应对算法更新 在互联网的迅速发展中,搜索引擎的算法更新频繁,这对SEO中文网站提出了更高的要求。面对这一挑战,我们需要深入分析问题,理解原因,并采取有效的应对策略。本文将详细探讨如何应对搜索引擎…...
HarmonyOS6 半年磨一剑 - RcSwitch 组件内联提示与外部文字系统深度解析
文章目录前言一、switchInlinePrompt:两种显示策略1.1 模式切换的总开关二、外部文字模式2.1 文字的动态位置:跟随状态切换2.2 外部文字的样式处理2.3 外部文字配置示例三、内联模式:文字与图标嵌入圆点区域3.1 内联渲染的结构原理3.2 图标优…...
JAVA打车小程序实现原理及开源uniapp代码片段
JAVA打车小程序实现原理打车小程序的核心功能包括用户端、司机端和后台管理系统。用户端实现叫车、订单管理、支付等功能;司机端实现接单、导航、收益管理等功能;后台管理系统负责订单监控、用户管理、数据统计等。用户端功能模块包括地图定位、路线规划…...
告别90%重复操作:XHS-Downloader如何重构小红书内容采集体验
告别90%重复操作:XHS-Downloader如何重构小红书内容采集体验 【免费下载链接】XHS-Downloader 小红书(XiaoHongShu、RedNote)链接提取/作品采集工具:提取账号发布、收藏、点赞、专辑作品链接;提取搜索结果作品、用户链…...
5个步骤安全使用YimMenu:GTA5 DLL注入入门指南
5个步骤安全使用YimMenu:GTA5 DLL注入入门指南 【免费下载链接】YimMenu YimMenu, a GTA V menu protecting against a wide ranges of the public crashes and improving the overall experience. 项目地址: https://gitcode.com/GitHub_Trending/yi/YimMenu …...
设备预测性维护模型构建方法
构建设备预测性维护模型需要结合数据采集、算法选择和实际应用场景。以下是核心步骤:数据采集与预处理 设备运行数据是模型的基础,需通过传感器、SCADA系统或IoT设备采集振动、温度、电流等参数。原始数据通常包含噪声,需进行滤波、归一化和缺…...
三步搞定空洞骑士模组管理:Scarab让复杂依赖关系变得简单
三步搞定空洞骑士模组管理:Scarab让复杂依赖关系变得简单 【免费下载链接】Scarab An installer for Hollow Knight mods written in Avalonia. 项目地址: https://gitcode.com/gh_mirrors/sc/Scarab 还在为《空洞骑士》模组安装的各种技术难题而头疼吗&…...
LingBot-Depth应用案例:智能机器人视觉感知的深度修复实战
LingBot-Depth应用案例:智能机器人视觉感知的深度修复实战 1. 引言:当机器人遇到"视觉障碍" 想象一下,你家的扫地机器人正在客厅工作,突然在玻璃茶几前停了下来——因为它"看"不到透明的玻璃表面。或者一个…...
5个实用场景展示:用Phi-3-mini轻松搞定文本改写与摘要整理
5个实用场景展示:用Phi-3-mini轻松搞定文本改写与摘要整理 1. 引言:为什么选择Phi-3-mini进行文本处理 在日常工作和学习中,我们经常需要处理各种文本任务:改写句子使其更专业、总结长篇文章的要点、快速生成内容草稿等。传统方…...
