0

0

JavaScript 中避免函数推入数组时立即执行

碧海醫心

碧海醫心

发布时间:2025-09-28 16:59:25

|

733人浏览过

|

来源于php中文网

原创

javascript 中避免函数推入数组时立即执行

本文旨在解决 JavaScript 中函数推入数组时立即执行的问题。通过将函数引用而非函数调用推入数组,并结合 Promise.all() 方法,可以实现函数的延迟执行,从而更好地控制异步任务的执行时机。本文将提供详细的示例代码和解释,帮助读者理解和应用这一技巧。

在 JavaScript 中,当我们将函数推入数组时,如果直接调用函数,它会立即执行。这在需要延迟执行函数,例如在使用 Promise.all() 并行执行多个异步任务时,会造成问题。解决的关键在于将函数引用(function reference)而非函数调用(function call)推入数组。

问题分析

考虑以下场景:我们希望并行执行多个 changePrice 函数,并将它们的结果传递给 Promise.all()。如果直接在 push 方法中调用 changePrice 函数,它会立即执行,而不是等待 Promise.all() 调用。

立即学习Java免费学习笔记(深入)”;

解决方案:使用函数引用

为了避免立即执行,我们需要将函数引用推入数组,而不是函数调用。这可以通过使用箭头函数或匿名函数来实现。

WPS AI
WPS AI

金山办公发布的AI办公应用,提供智能文档写作、阅读理解和问答、智能人机交互的能力。

下载

示例代码

以下代码展示了如何使用函数引用来避免函数立即执行:

async function changePrice(id, price, type) {
  // 模拟异步操作
  return new Promise(resolve => {
    setTimeout(() => {
      console.log(`Changing price for id: ${id}, price: ${price}, type: ${type}`);
      resolve(`Price changed for id: ${id}`);
    }, 500);
  });
}

async function processPrices(prices, minPrices, mainProduct) {
  let childChanges = [];
  let parentChanges = [];

  prices.map(price => {
    const minPrice = minPrices.find(_price => _price.TYPE === price.TYPE);
    if (minPrice) {
      // 推入函数引用,而不是函数调用
      parentChanges.push(() => changePrice(mainProduct.ID, minPrice.PRICE, minPrice.TYPE));
    }
    // 推入函数引用,而不是函数调用
    childChanges.push(() => changePrice(price.ID, price.PRICE, price.TYPE));
  });

  // 使用 Promise.all 执行异步任务
  const childResults = await Promise.all(childChanges.map(task => task()));
  const parentResults = await Promise.all(parentChanges.map(task => task()));

  console.log('Child results:', childResults);
  console.log('Parent results:', parentResults);
}

// 模拟数据
const prices = [
  { ID: 1, PRICE: 10, TYPE: 'A' },
  { ID: 2, PRICE: 20, TYPE: 'B' }
];
const minPrices = [
  { TYPE: 'A', PRICE: 5 },
  { TYPE: 'B', PRICE: 15 }
];
const mainProduct = { ID: 100 };

// 调用主函数
processPrices(prices, minPrices, mainProduct);

代码解释

  1. changePrice 函数: 模拟一个异步操作,返回一个 Promise,并在一段时间后 resolve。
  2. processPrices 函数: 遍历 prices 数组,并将函数引用推入 childChanges 和 parentChanges 数组。关键在于使用箭头函数 () => changePrice(...) 来创建函数引用。
  3. Promise.all 执行: 使用 Promise.all 并结合 map(task => task()) 来执行数组中的函数。task() 调用函数引用,从而执行实际的 changePrice 函数。

注意事项

  • 确保推入数组的是函数引用,而不是函数调用。函数调用会立即执行函数,而函数引用则会将函数作为值存储在数组中,等待后续执行。
  • 在使用 Promise.all 执行函数引用时,需要使用 map(task => task()) 来调用数组中的每个函数。
  • changePrice 函数需要返回一个 Promise,以便 Promise.all 可以正确地处理异步任务。

总结

通过将函数引用推入数组,并结合 Promise.all() 方法,我们可以避免函数在推入数组时立即执行,从而更好地控制异步任务的执行时机。这种方法在处理大量异步任务时非常有用,可以提高代码的可维护性和可读性。 记住,理解函数引用和函数调用的区别是掌握这一技巧的关键。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

36

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

61

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

42

2025.11.27

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

483

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

163

2023.10.07

promise的用法
promise的用法

“promise” 是一种用于处理异步操作的编程概念,它可以用来表示一个异步操作的最终结果。Promise 对象有三种状态:pending(进行中)、fulfilled(已成功)和 rejected(已失败)。Promise的用法主要包括构造函数、实例方法(then、catch、finally)和状态转换。

306

2023.10.12

html文本框类型介绍
html文本框类型介绍

html文本框类型有单行文本框、密码文本框、数字文本框、日期文本框、时间文本框、文件上传文本框、多行文本框等等。详细介绍:1、单行文本框是最常见的文本框类型,用于接受单行文本输入,用户可以在文本框中输入任意文本,例如用户名、密码、电子邮件地址等;2、密码文本框用于接受密码输入,用户在输入密码时,文本框中的内容会被隐藏,以保护用户的隐私;3、数字文本框等等。

406

2023.10.12

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

7

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.3万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.6万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号