关于前端:深入-JavaScript-中的默认参数

43次阅读

共计 3807 个字符,预计需要花费 10 分钟才能阅读完成。

译者:前端小智
作者:Tania Rascia
起源:flatlogic.com

有幻想,有干货,微信搜寻 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。

本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试残缺考点、材料以及我的系列文章。

我是小智,明天,咱们来讲讲默认参数。

在 ES6 中,JS 引入了默认函数参数。如果未向函数调用提供实参,则容许开发人员用默认值初始化函数。以这种形式初始化函数参数将使函数更容易浏览,更不易出错,并为函数提供默认行为。这也帮忙咱们防止因为传入未定义的参数和解构不存在的对象而产生的谬误。

在本文中,咱们将学习一下形参和实参之间的区别,理解如何在函数中应用默认形参,理解反对默认形参的其余办法,并理解哪些类型的值和表达式能够用作默认形参。

实参和形参

在解释默认函数参数之前,重要的是要晓得参数的默认值是什么。所以咱们先回顾函数中实参和形参之间的区别。

在上面的代码中,咱们创立一个函数,该函数返回一个给定数的立方:

function cube(x) {return x * x * x}

此示例中的 x 变量是一个参数 - 传递给函数的命名变量,参数必须始终蕴含在变量中。接着,咱们来调用一下这个函数:

cube(10) // 1000

在这种状况下,10是一个参数—调用时传递给函数的值。通常,值也能够用变量,如:

const number = 10

cube(number) // 1000

如果没有将参数传递该函数,函数将隐式地应用 undefined 作为默认值:

cube() // NaN

在本例中,cube()试图计算 undefined * undefined * undefined 的值,后果是NaN

这种主动的行为有时会造成问题。在某些状况下,咱们心愿参数具备一个值,即便没有向函数传递参数。这就是默认参数个性派上用场的中央。

默认参数语法

如果没有默认参数,咱们就须要显式查看 undefined 的值能力设置默认值,如以下示例所示:

function cube(x) {if (typeof x === 'undefined') {x = 5}

  return x * x * x
}

cube()

相同,应用默认参数能够用更少的代码实现雷同的指标。能够通过应用等式赋值运算符(=)为多维数据集中的参数设置默认值,如下所示:

function cube(x = 5) {return x * x * x}

当初,在不带参数的状况下调用多维数据集函数时,它将为 x5并返回计算而不是NaN

传递参数时,它仍将按预期运行,而疏忽默认值:

cube(2)  // 8

须要留神的一个中央,默认参数值还将笼罩作为函数的参数传递的undefined,如下所示:

cube(undefined)  // 125

这里是应用默认参数 5 来计算的,显示的传递 undefined 会被疏忽。

默认参数数据类型

任何原始值或对象都能够用作默认参数值。首先,应用 number, string, boolean,objectarraynull 作为默认值来设置参数。

const defaultNumber = (number = 42) => console.log(number)
const defaultString = (string = 'Shark') => console.log(string)
const defaultBoolean = (boolean = true) => console.log(boolean)
const defaultObject = (object = { id: 7}) => console.log(object)
const defaultArray = (array = [1, 2, 3]) => console.log(array)
const defaultNull = (nullValue = null) => console.log(nullValue)

在不带参数的状况下调用这些函数时,它们都将应用默认值:

defaultNumber()  // 42
defaultString()  // "Shark"
defaultBoolean() // true
defaultObject()  // {id: 7}
defaultArray()   // (3) [1, 2, 3]
defaultNull()    // null

留神,在默认参数中创立的任何对象都将在每次调用函数时创立。默认参数的一个常见用例是应用这种行为从对象中获取值。如果咱们试图从一个不存在的对象中解构或拜访一个值,它将抛出一个谬误。然而,如果默认参数是一个空对象,那么它只会给出undefined 的值,而不会抛出谬误。

function settings(options = {}) {const { theme, debug} = options

  // Do something with settings
}

这样防止因解构不存在的对象而导致的谬误。

当初咱们曾经看到了默认参数如何与不同的数据类型一起工作,上面咱们来看看多个默认参数如何协同工作。

应用多个默认参数

首先,申明一个带有多个默认参数的 sum() 函数

function sum(a = 1, b = 2) {return a + b}

sum() // 3

此外,参数中应用的值能够在任何后续的默认参数中应用,从左到右。例如,这个 createUser 函数创立了一个用户对象 userObj 作为第三个参数,函数自身所做的就是返回 userObj 和前两个参数

function createUser(name, rank, userObj = { name, rank}) {return userObj}

// Create user
const user = createUser('前端小智', '前端开发')

console.log(user) // {name: "前端小智", rank: "前端开发"}

通常倡议将所有默认参数放在参数列表的开端,以便能够轻松保留可选值。如果首先应用默认参数,则必须显式传递 undefined 能力应用默认值。

function defaultFirst(a = 1, b) {return a + b}

当调用这个函数时,必须调用带有两个参数的defaultFirst():

efaultFirst(undefined, 2)  // 3

实战中的事例,上面是一个函数,它的作用是创立一个 DOM 元素,并增加一个文本标签和类(如果存在的话)。

function createNewElement(tag, text, classNames = []) {const el = document.createElement(tag)
  el.textContent = text

  classNames.forEach((className) => {el.classList.add(className)
  })

  return el
}

const greeting = createNewElement('p', 'Hello!', ['greeting', 'active'])

此时 greeting 的值为

<p class="greeting active">Hello!</p>

如果将 classNames 数组保留在函数调用之外,则该数组仍将起作用。

const greeting2 = createNewElement('p', 'Hello!')

console.log(greeting2) // p>Hello!</p>

函数调用作为默认参数

除了原始类型和对象外,调用函数的后果能够用作默认参数。

在上面代码中,创立一个返回随机数的函数,而后将后果用作多维数据集函数中的默认参数值:

function getRandomNumber() {return Math.floor(Math.random() * 10)
}


function cube(x = getRandomNumber()) {return x * x * x}

当初每次调用 cube 后果可能都会不一样:

cube()  // 512
cube()  // 64

在以下示例中,将一个随机数调配给 x,该随机数用作咱们创立函数中的参数。而后,y 参数将计算数字的立方根,并查看 xy是否相等:

function doesXEqualY(x = getRandomNumber(), y = Math.cbrt(cube(x))) {return x === y}

doesXEqualY() // true

默认参数甚至能够是函数定义,如本例所示,它将参数定义为外部函数并返回参数的函数调用:

function outer(parameter = function inner() {return 100}
) {return parameter()
}

// Invoke outer function
outer() // 100

总结

在本文中,咱们理解了什么是默认函数参数以及如何应用它们。当初,咱们能够应用默认参数来帮忙放弃函数的整洁和易于浏览。还能够事后将空对象和数组调配给参数,以便在解决从对象中检索值或遍历数组等状况时缩小复杂性和代码行数。

我是小智,咱们下期见!


编辑中可能存在的 bug 没法实时晓得,预先为了解决这些 bug, 花了大量的工夫进行 log 调试,这边顺便给大家举荐一个好用的 BUG 监控工具 Fundebug。

原文:https://www.taniarascia.com/d…

交换

文章每周继续更新,能够微信搜寻 【大迁世界】 第一工夫浏览,回复 【福利】 有多份前端视频等着你,本文 GitHub https://github.com/qq449245884/xiaozhi 曾经收录,欢送 Star。

正文完
 0