ES6 里面的函数默认参数详解

ES6 里面的函数默认参数详解

在 ES6 中,我们允许为函数的参数设置默认值,从而使得函数调用者在某些情况下可以省略掉某些参数的值。本篇文章将详细讲解 ES6 中函数默认参数的相关知识点,并提供一些实例代码来帮助大家更好地理解。

函数默认参数的基本语法

在 ES6 中,我们可以使用如下语法来为函数参数设置默认值:

-------- ------------------------ ------------------- ---- -
  -- ---
-

在上述代码中,我们使用了 = 运算符来为参数 param1param2 设置了默认值 defaultVal1defaultVal2。当函数调用者没有给这些参数传递值时,函数将会默认使用这些值。

示例代码:

-------- ----------- -------------- -
  ------------------------- -----------
-

--------------  -- -- ---- ------
------------- ---------  -- -- ------- ------

在上述代码中,我们定义了一个名为 greet 的函数,它接受两个参数:name 表示要打招呼的人的名字,greeting 表示打招呼的话语。当函数调用者没有传递 greeting 参数的值时,默认为 'Hi'。这意味着我们可以在调用 greet 函数时省略掉 greeting 参数。

函数默认参数对于 undefined 的判断

当函数的参数值被传递进来时,我们需要注意的是参数值为 undefined 和参数值没有被传递进来这两种情况是不同的。

示例代码:

-------- ---------- - ---------- -
  -------------------
-

-------         -- -- ---------
------------------ -- ---------
-----------     -- -- ----

在上述代码中,我们定义了一个名为 func 的函数,并为其设置了一个默认参数 param,默认值为 'default'。在函数调用时,我们可以看到传递不同的参数值会引起不同的输出。特别是,当我们向 func 函数传递 undefined 进行调用时,将输出默认值。

函数默认参数按值传递

与 JavaScript 中的其他函数参数类似,函数默认参数也是按值传递的。这意味着如果我们将一个对象作为函数的默认参数值传递进去,那么函数内部使用的对象值与函数外部的对象是不同的。

示例代码:

-------- -------------- -
  ------- - --
  -------------------
-

-------      -- -- --- --
-------      -- -- --- --
--- ----- - ---
------------  -- -- --- --
------------------- -- -- --

在上述代码中,我们定义了一个名为 func 的函数,并为其设置了一个默认参数 param,默认值为一个空对象。在函数内部,我们将 param 对象的 x 属性值修改为了 1。当我们第一次调用 func 函数时,输出的是 {x: 1}。当我们第二次调用 func 函数时,输出的仍然是 {x: 1}。这是因为函数内部使用的对象值与函数外部的对象是不同的。最后,我们在第三次调用 func 函数时传递了一个自定义的对象 myObj 进去,输出的是 {x: 1}。然而,我们注意到函数外部的对象仍然是一个空对象。这表明在函数内部修改对象的属性值不会影响到函数外部对象的值。

总结

在 ES6 中,我们可以使用函数默认参数的语法来使函数的调用更加灵活。默认值是参数没有被传入时使用的值。通过本篇文章,我们学会了如何设置函数的默认参数,了解了函数默认参数的在 undefined 和对象参数值的场景下的表现形式,并知道函数默认参数是按值传递的。我们希望这篇文章可以帮助大家更好地理解 ES6 中函数默认参数的相关知识点,以便进一步加深对 JavaScript 语言的掌握程度。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/6534e5877d4982a6eba646c8


猜你喜欢

  • 如何使用 Enzyme 测试 React 组件的 ref 属性?

    React 在构建前端应用中具有重要的作用,而 Enzyme 则是 React 测试中不可缺少的一部分。在测试 React 组件时,有时需要测试组件上的 ref 属性,本文将介绍如何使用 Enzyme...

    1 年前
  • Redis 中如何实现多线程并发读取

    Redis 中如何实现多线程并发读取 Redis 是一款开源的内存数据存储系统,具有高性能、高可用、高可扩展性等优点,被广泛应用于 Web 缓存、会话存储、消息队列、排行榜、实时计数等场景。

    1 年前
  • Node.js 中发生异常时如何进行错误处理

    Node.js 是一门非常流行的服务器端 JavaScript 运行时环境。在开发过程中,错误和异常是难免存在的。因此,在编写代码时,我们需要考虑如何进行异常处理。

    1 年前
  • Mongoose 连接 MongoDB 时出现错误解决方案

    如果你在使用 Mongoose 连接 MongoDB 数据库时遇到了错误,本文将为你提供解决方案。Mongoose 是一个流行的 Node.js ORM 库,它允许你在 Node.js 应用程序中使用...

    1 年前
  • Serverless 架构下如何实现 WebSocket 消息推送?

    什么是 Serverless 架构? Serverless 架构是一种基于云计算的应用开发模式,它的基本思想是将应用中的某些功能模块运行在云端,由云平台提供服务,而应用中的其他模块则在本地部署并运行。

    1 年前
  • 调试 Redux 应用的技巧和工具

    Redux 是一个流行的 JavaScript 应用程序状态管理工具。它使用几个重要的概念,如 store、reducer、action 和 dispatch,来使应用程序状态管理变得更加简单和可控。

    1 年前
  • ECMAScript 2016 中的 Object 扩展:如何进行对象的冻结、密封和可扩展状态控制

    在 JavaScript 中,对象是非常重要的基础概念。因此,ECMAScript 2016 引入了 Object 扩展,包括了对象的冻结、密封和可扩展状态控制。 什么是对象冻结? 对象冻结是一种机制...

    1 年前
  • 初学者 Docker 容器网络配置,不容错过

    什么是 Docker 容器网络? 在 Docker 中,容器网络是一种在主机内创建虚拟网络的方式。每个容器都可以加入一个或多个网络,并在其中运行自己的服务。这种网络可以是私有的,也可以是公共的。

    1 年前
  • ES2021 之可选链操作演示

    在前端开发中,我们经常会遇到需要处理嵌套对象的情况,而在早期的 JavaScript 版本中,处理嵌套对象时需要用到很多繁琐的判断语句来保证代码安全性。这样的做法既低效又容易出错,让开发者在编写代码时...

    1 年前
  • 详解 ES8 中的 rest 操作符

    在 ES6 中,我们已经了解了箭头函数、模板字符串、解构赋值等重要的特性,这些特性已经极大地提高了 JavaScript 的开发效率。而在 ES8 中,新增了 rest 操作符,使其拥有更好的可读性和...

    1 年前
  • vue-cli 3.0 源码解读之 webpack4.0 篇

    Vue-CLI 3.0 是一个用于快速搭建 Vue.js 项目的脚手架工具,它集成了大量的工具,其中包括 Webpack 4.0。在使用 Vue-CLI 3.0 搭建项目时,Webpack 扮演着非常...

    1 年前
  • ES10 如何使用 Optional Catch Binding 解决代码错误

    随着 JavaScript 语言的不断发展,新特性和新语法层出不穷。ES10 也并不例外,除了一些新的 API 和语言特性,Optional Catch Binding 是其一个非常有用的新特性,它能...

    1 年前
  • 如何创造出一个最优的 ESLint 配置文件

    如何创造出一个最优的 ESLint 配置文件 ESLint 是一个强大的 JavaScript 语法检查工具,它可以检测出代码的潜在问题,提供代码质量的保障。随着前端技术发展的不断提升,ESLint ...

    1 年前
  • 使用 Webpack4 打包 SPA 时,如何实现文件版本号控制及缓存优化

    前置知识 在介绍如何使用 Webpack4 实现文件版本号控制和缓存优化之前,需要了解一些前置知识: Cache-Control:HTTP 响应头中的一个字段,用于控制浏览器如何缓存页面和静态资源。

    1 年前
  • Socket.io 在 React Native 中的使用教程

    本文将介绍如何在 React Native 中使用 Socket.io 实现实时通讯。Socket.io 是一个基于 WebSocket 协议的封装库,它可以在客户端和服务器端之间实现双向通讯,且支持...

    1 年前
  • Koa2 中使用 Nodemailer 发送邮件的方法

    在现代的前端开发中,电子邮件服务扮演着非常重要的角色。通过电子邮件,我们可以完成很多事情,比如注册、验证、通知等等。在本文中,我们将介绍如何在 Koa2 中使用 Nodemailer 发送电子邮件。

    1 年前
  • 在 Deno 中如何正确地使用 web workers 进行并行计算?

    在前端开发的过程中,我们常常需要进行大量的计算,而这些计算通常会占用大量的时间,影响了应用的性能。一种解决这个问题的方法是使用并行计算来加速这些计算任务的执行。而在 Deno 中,Web Worker...

    1 年前
  • 如何使用 Enzyme 测试 React 组件的 prop 传递?

    前言 在 React 的开发中,有时需要对组件进行测试以确保组件的正确性和稳定性。而 Enzyme 是一个非常流行的 React 组件测试工具,它提供了一种方便灵活的方式来测试 React 组件。

    1 年前
  • Redis 中的 Lock 优化及互斥锁的使用方法

    Redis 是一种高性能键值对存储服务,用于缓存和消息队列等场景,广泛应用于互联网领域。在实际开发中,我们通常需要使用 Redis 来实现分布式锁,保证系统的并发安全性。

    1 年前
  • Cypress 如何对不同页面进行测试

    Cypress 是一款流行的前端测试工具,可以执行端到端的自动化测试,并提供了一系列的 API,使得测试变得更加简易和可读。在进行测试时,有时需要对不同的页面进行测试,本文将介绍如何在 Cypress...

    1 年前

相关推荐

    暂无文章