ES6 中函数参数的默认值

ES6 引入了函数参数的默认值(Default Parameters)功能,允许在函数定义时为某些参数提供默认值。当调用函数时,如果这些参数没有传递值(或传递的值为 undefined),则会使用默认值。

1. 基本语法

默认值语法非常简单,只需要在参数名后使用等号 = 来指定默认值:
 

function greet(name = 'Guest') {console.log(`Hello, ${name}!`);
}greet();         // 输出: Hello, Guest!
greet('Alice');  // 输出: Hello, Alice!

在上面的例子中,name 参数的默认值是 'Guest'。当调用 greet() 时,如果没有传递 name 参数,函数会使用默认值 'Guest'

2. 多个参数的默认值

你可以为多个函数参数设置默认值:
 

function createProfile(name = 'John Doe', age = 30) {console.log(`Name: ${name}, Age: ${age}`);
}createProfile();              // 输出: Name: John Doe, Age: 30
createProfile('Alice');       // 输出: Name: Alice, Age: 30
createProfile('Bob', 25);     // 输出: Name: Bob, Age: 25

如果只传递了一个参数,另一个参数会使用它的默认值。

3. 默认值与其他参数的结合

默认参数可以与其他普通参数结合使用,只要确保默认参数的位置在没有默认值的参数之后。例如:
 

function sum(a, b = 5, c = 10) {return a + b + c;
}console.log(sum(2));         // 输出: 17, 因为 b 默认是 5, c 默认是 10
console.log(sum(2, 3));      // 输出: 15, 因为 c 默认是 10
console.log(sum(2, 3, 4));   // 输出: 9

4. 动态计算默认值

默认值也可以是一个表达式,甚至可以是一个函数调用。这个表达式会在函数调用时求值并赋值给参数:
 

function getMax(a, b = Math.max(a, 100)) {console.log(`Max value: ${b}`);
}getMax(50);  // 输出: Max value: 100
getMax(200); // 输出: Max value: 200

在上面的例子中,如果 b 没有传递值,默认值 Math.max(a, 100) 会被计算出来。

5. 默认值与 undefined 的行为

需要注意的是,默认值只在参数为 undefined 时生效。如果传递了 null 或其他值,则不会使用默认值:
 

function greet(name = 'Guest') {console.log(`Hello, ${name}!`);
}greet(undefined); // 输出: Hello, Guest!
greet(null);      // 输出: Hello, null!

6. 与解构赋值的结合

当函数参数是一个对象或数组时,可以与解构赋值结合使用,为解构的属性设置默认值:
 

// 对象解构
function printUserInfo({ name = 'Guest', age = 18 } = {}) {console.log(`Name: ${name}, Age: ${age}`);
}printUserInfo();                        // 输出: Name: Guest, Age: 18
printUserInfo({ name: 'Alice' });        // 输出: Name: Alice, Age: 18
printUserInfo({ age: 25 });              // 输出: Name: Guest, Age: 25// 数组解构
function printCoordinates([x = 0, y = 0] = []) {console.log(`X: ${x}, Y: ${y}`);
}printCoordinates();             // 输出: X: 0, Y: 0
printCoordinates([10]);         // 输出: X: 10, Y: 0
printCoordinates([10, 20]);     // 输出: X: 10, Y: 20

总结

ES6 的函数参数默认值简化了代码,使得函数更加灵活和易用。它允许开发者为函数参数设置默认值,避免了在函数内部编写冗长的检查代码。同时,默认值的引入使得代码更加简洁、易懂,并且能够与其他特性(如解构赋值)结合使用,提升了编程效率。

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

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

相关文章

SAP ABAP调用DeepSeek API大模型接口

搜索了一下DeepSeek,发现有人已经实现了SAP的对接, 不登录网页,SAP如何使用DeepSeek快速编程,ABAP起飞啦~ 按照对应的注册流程和方法。总算做出了第一个能够直连DeepSeek的API abap程序。 效果不错。 report ZTOOL_ABAP_CALL_D…

verilog练习:i2c slave 模块设计

文章目录 前言1. 结构2.代码2.1 iic_slave.v2.2 sync.v2.3 wr_fsm.v2.3.1 状态机状态解释 2.4 ram.v 3. 波形展示4. 建议5. 资料总结 前言 首先就不啰嗦iic协议了,网上有不少资料都是叙述此协议的。 下面将是我本次设计的一些局部设计汇总,如果对读者有…

活动预告 |【Part 1】Microsoft 安全在线技术公开课:通过扩展检测和响应抵御威胁

课程介绍 通过 Microsoft Learn 免费参加 Microsoft 安全在线技术公开课,掌握创造新机遇所需的技能,加快对 Microsoft Cloud 技术的了解。参加我们举办的“通过扩展检测和响应抵御威胁”技术公开课活动,了解如何更好地在 Microsoft 365 Defen…

【电机控制器】STC8H1K芯片——低功耗

【电机控制器】STC8H1K芯片——低功耗 文章目录 [TOC](文章目录) 前言一、芯片手册说明二、IDLE模式三、PD模式四、PD模式唤醒五、实验验证1.接线2.视频(待填) 六、参考资料总结 前言 使用工具: 1.STC仿真器烧录器 提示:以下是本…

校园网规划方案

个人博客站—运维鹿: http://www.kervin24.top CSDN博客—做个超努力的小奚: https://blog.csdn.net/qq_52914969?typeblog 本课程设计参考学习计算机网络 思科Cisco Packet Tracer仿真实验_哔哩哔哩_bilibili, 文章和pkg详见个人博客站: http://www.kervin24.to…

用 DeepSeek + Kimi 自动做 PPT,效率起飞

以下是使用 DeepSeek Kimi 自动做 PPT 的详细操作步骤: 利用 DeepSeek 生成 PPT 内容: 访问 DeepSeek 官网,完成注册/登录后进入对话界面。输入指令,例如“请用 Markdown 格式生成一份关于[具体主题]的 PPT 大纲,需包…

【Matlab优化算法-第14期】基于智能优化算法的VMD信号去噪项目实践

基于智能优化算法的VMD信号去噪项目实践 一、前言 在信号处理领域,噪声去除是一个关键问题,尤其是在处理含有高斯白噪声的复杂信号时。变分模态分解(VMD)作为一种新兴的信号分解方法,因其能够自适应地分解信号而受到…

8.JVM-方法区

前言 这次所讲述的是运行时数据区的最后一个部分 从线程共享与否的角度来看 ThreadLocal:如何保证多个线程在并发环境下的安全性?典型应用就是数据库连接管理,以及会话管理 栈、堆、方法区的交互关系 下面就涉及了对象的访问定位 Person&a…

大模型训练(7):集合通信与通信原语

0 背景 分布式训练过程中设计到许多通信上的操作, 每个操作有其不同的术语并且有所区别,这里将其用简单的例子和描述总结一下,方便理解。 集合通信(Collective Communications)是一个进程组的所有进程都参与的全局通…

全程Kali linux---CTFshow misc入门(38-50)

第三十八题: ctfshow{48b722b570c603ef58cc0b83bbf7680d} 第三十九题: 37换成1,36换成0,就得到长度为287的二进制字符串,因为不能被8整除所以,考虑每7位转换一个字符,得到flag。 ctfshow{5281…

C++Primer学习(2.2)

2.2 变量 变量提供一个具名的、可供程序操作的存储空间。C中的每个变量都有其数据类型,数据类型决定着变量所占内存空间的大小和布局方式、该空间能存储的值的范围,以及变量能参与的运算。对C程序员来说,“变量(variable)”和“对象(object)”一般可以互换使用。 术…

Maven 安装配置(完整教程)

文章目录 一、Maven 简介二、下载 Maven三、配置 Maven3.1 配置环境变量3.2 Maven 配置3.3 IDEA 配置 四、结语 一、Maven 简介 Maven 是一个基于项目对象模型(POM)的项目管理和自动化构建工具。它主要服务于 Java 平台,但也支持其他编程语言…

基于Java的远程视频会议系统(源码+系统+论文)

第一章 概述 1.1 本课题的研究背景 随着人们对视频和音频信息的需求愈来愈强烈,追求远距离的视音频的同步交互成为新的时尚。近些年来,依托计算机技术、通信技术和网络条件的发展,集音频、视频、图像、文字、数据为一体的多媒体信息&#xff…

DeepSeek为何能爆火

摘要:近年来,DeepSeek作为一款新兴的社交媒体应用,迅速在年轻人群体中走红,引发了广泛关注。本文旨在探讨DeepSeek为何能在短时间内爆火,从而为我国社交媒体的发展提供参考。首先,通过文献分析,…

数据分析如何做EDA

探索性数据分析(EDA,Exploratory Data Analysis)是数据分析过程中至关重要的一步,其目的是通过统计和可视化技术对数据进行初步分析,从而揭示数据的潜在模式、特征和异常值,并为后续的数据预处理、特征工程…

Unity-Mirror网络框架-从入门到精通之Discovery示例

文章目录 前言Discovery示例NetworkDiscoveryNetworkDiscoveryHUDServerRequestServerResponse最后前言 在现代游戏开发中,网络功能日益成为提升游戏体验的关键组成部分。本系列文章将为读者提供对Mirror网络框架的深入了解,涵盖从基础到高级的多个主题。Mirror是一个用于Un…

哈佛大学“零点项目”(Project Zero)简介

哈佛大学“零点项目”(Project Zero)简介 起源与背景 “零点项目”(Project Zero)由美国哲学家纳尔逊古德曼(Nelson Goodman)于1967年在哈佛大学教育研究院创立。名称源于“从零开始研究艺术教育”的理念&…

【机器学习】数据预处理之scikit-learn的Scaler与自定义Scaler类进行数据归一化

scikit-learn的Scaler数据归一化 一、摘要二、训练数据集和测试数据集的归一化处理原则三、scikit-learn中的Scalar类及示例四、自定义StandardScaler类进行数据归一化处理五、小结 一、摘要 本文主要介绍了scikit-learn中Scaler的使用方法,特别强调了数据归一化在…

MySQL视图索引操作

创建学生表; mysql> create table Student(-> Sno int primary key auto_increment,-> Sname varchar(30) not null unique,-> Ssex char(2) check (Ssex男 or Ssex女) not null,-> Sage int not null,-> Sdept varchar(10) default 计算机 not …

知识库升级新思路:用生成式AI打造智能知识助手

在当今信息爆炸的时代,企业和组织面临着海量数据的处理和管理挑战。知识库管理系统(Knowledge Base Management System, KBMS)作为一种有效的信息管理工具,帮助企业存储、组织和检索知识。然而,传统的知识库系统往往依…