0

0

JavaScript 中使用 Rest 参数实现函数的灵活参数传递

聖光之護

聖光之護

发布时间:2026-02-09 23:34:25

|

472人浏览过

|

来源于php中文网

原创

JavaScript 中使用 Rest 参数实现函数的灵活参数传递

本文介绍如何利用 javascript 的 rest 参数语法,让函数能接收任意数量的回调函数作为参数,避免硬编码参数名,提升代码复用性与可维护性。

在实际开发中,我们常需要设计高阶函数(higher-order function),例如一个主函数负责统一调度、日志记录、错误处理或异步编排,而将具体业务逻辑以多个回调函数的形式注入。若采用固定参数签名(如 mainFunction(fn1, fn2, fn3)),不仅扩展性差(新增函数需修改函数定义),还难以支持动态数量的函数传入。

此时,Rest 参数(...functions) 是最简洁、标准且语义清晰的解决方案。它允许函数接收零个或多个参数,并自动将其聚合为一个真数组(Array 实例),从而支持遍历、映射、过滤等原生数组操作。

永利在线企业网站管理系统(CMS)1.0 Build 20100612
永利在线企业网站管理系统(CMS)1.0 Build 20100612

修正说明:1,实现真正的软件开源。2,安装界面的美化3,真正实现栏目的递归无限极分类。4,后台添加幻灯片图片的管理,包括添加,修改,删除等。5,修正添加新闻的报错信息6,修正网站参数的logo上传问题7,修正产品图片的栏目无限极分类8,修正投票系统的只能单选问题9,添加生成静态页功能10,添加缓存功能特点和优势1. 基于B/S架构,通过本地电脑、局域网、互联网皆可使用,使得企业的管理与业务不受地域

下载

✅ 正确写法:使用 Rest 参数接收任意数量函数

const mainFunction = async (...functions) => {
  // functions 是一个包含所有传入函数的数组
  if (functions.length === 0) {
    throw new Error('At least one function must be provided');
  }

  // 示例:统一执行所有函数,并收集返回值(并行)
  try {
    const results = await Promise.all(
      functions.map(async (fn, index) => {
        console.log(`Executing function #${index + 1}`);
        return await fn(); // 假设每个函数都返回 Promise
      })
    );
    return results;
  } catch (error) {
    console.error('One or more functions failed:', error);
    throw error;
  }
};

// 调用方式 —— 完全自由:1 个、3 个、5 个函数均可
const fn1 = () => Promise.resolve('Result A');
const fn2 = () => Promise.resolve('Result B');
const fn3 = () => Promise.reject(new Error('Oops!'));

await mainFunction(fn1, fn2); 
// → ['Result A', 'Result B']

await mainFunction(fn1, fn2, fn3); 
// → 抛出错误(由 Promise.all 统一捕获)

⚠️ 注意事项与最佳实践

  • Rest 参数必须位于参数列表末尾:async (...functions, options) 是非法语法;正确形式是 async (options, ...functions) 或仅 async (...functions)。
  • 与解构赋值结合更强大:若还需接收配置对象,可先解构再用 rest:
    const mainFunction = async ({ timeout = 5000, parallel = true }, ...functions) => { /* ... */ };
    await mainFunction({ parallel: false }, fn1, fn2, fn3);
  • 类型安全提示(TypeScript):建议显式标注类型,提高可读性与 IDE 支持:
    const mainFunction = async (...functions: Array<() => Promise>) => {
      return Promise.all(functions.map(fn => fn()));
    };

✅ 总结

摒弃固定参数签名,拥抱 ...functions 语法,是编写可扩展高阶函数的关键一步。它不仅符合 JavaScript 语言规范(ES2015+),还能显著降低耦合度、增强函数复用能力,并为后续支持中间件链、插件系统等高级模式奠定基础。记住:当参数数量不确定时,rest 参数不是“技巧”,而是标准解法。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

180

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

222

2025.12.18

function是什么
function是什么

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

490

2023.08.04

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

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

165

2023.10.07

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

132

2026.02.06

java多线程方法汇总
java多线程方法汇总

本专题整合了java多线程面试题、实现函数、执行并发相关内容,阅读专题下面的文章了解更多详细内容。

52

2026.02.06

1688阿里巴巴货源平台入口与批发采购指南
1688阿里巴巴货源平台入口与批发采购指南

本专题整理了1688阿里巴巴批发进货平台的最新入口地址与在线采购指南,帮助用户快速找到官方网站入口,了解如何进行批发采购、货源选择以及厂家直销等功能,提升采购效率与平台使用体验。

749

2026.02.06

快手网页版入口与电脑端使用指南 快手官方短视频观看入口
快手网页版入口与电脑端使用指南 快手官方短视频观看入口

本专题汇总了快手网页版的最新入口地址和电脑版使用方法,详细提供快手官网直接访问链接、网页端操作教程,以及如何无需下载安装直接观看短视频的方式,帮助用户轻松浏览和观看快手短视频内容。

443

2026.02.06

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

48

2026.02.06

热门下载

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

精品课程

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

共58课时 | 4.8万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.3万人学习

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

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