js css html

ES6 函数的扩展

2023-02-22  本文已影响0人  Cherry丶小丸子
函数参数的默认值

ES6 之前,不能直接为函数的参数指定默认值,只能采用变通的方法

function log(x, y) {
    y = y || 'World';
    console.log(x, y);
}

log('Hello') // Hello World
log('Hello', 'China') // Hello China
log('Hello', '') // Hello World

上面代码检查函数 log() 的参数 y 有没有赋值,如果没有,则指定默认值为 World。
这种写法的缺点在于,如果参数 y 赋值了,但是对应的布尔值为 false,则该赋值不起作用。
就像上面代码的最后一行,参数 y 等于空字符,结果被改为默认值

ES6 允许为函数的参数设置默认值,即直接写在参数定义的后面

function log(x, y = 'World') {
    console.log(x, y);
}

log('Hello') // Hello World
log('Hello', 'China') // Hello China
log('Hello', '') // Hello

参数变量是默认声明的,所以不能用 let 或 const 再次声明

function foo(x = 5) {
    let x = 1; // error
    const x = 2; // error
}

使用参数默认值时,函数不能有同名参数

// 不报错
function foo(x, x, y) {
    // ...
}

// 报错
function foo(x, x, y = 1) {
    // ...
}
// SyntaxError: Duplicate parameter name not allowed in this context
与解构赋值默认值结合使用
function foo({x, y = 5}) {
    console.log(x, y);
}

foo({}) // undefined 5
foo({x: 1}) // 1 5
foo({x: 1, y: 2}) // 1 2
foo() // TypeError: Cannot read property 'x' of undefined

上面代码只使用了对象的解构赋值默认值,没有使用函数参数的默认值
只有当函数foo()的参数是一个对象时,变量x和y才会通过解构赋值生成。如果函数foo()调用时没提供参数,变量x和y就不会生成,从而报错

通过提供函数参数的默认值,就可以避免这种情况

function foo({x, y = 5} = {}) {
    console.log(x, y);
}
foo() // undefined 5
参数默认值的位置
通常情况下,定义了默认值的参数,应该是函数的尾参数。
因为这样比较容易看出来,到底省略了哪些参数。
如果非尾部的参数设置默认值,实际上这个参数是没法省略的。
函数的 length 属性
(function (a) {}).length // 1
(function (a = 5) {}).length // 0
(function (a, b, c = 5) {}).length // 2

指定了默认值以后,函数的length属性,将返回没有指定默认值的参数个数。也就是说,指定了默认值后,length属性将失真

同理,后文的 rest 参数也不会计入length属性
(function(...args) {}).length // 0
rest 参数

ES6 引入 rest 参数(形式为...变量名),用于获取函数的多余参数,这样就不需要使用 arguments 对象了。rest 参数搭配的变量是一个数组,该变量将多余的参数放入数组中

function add(...values) {
    console.log(values) // [2, 5, 3]
    let sum = 0;

    for (var val of values) {
        sum += val;
    }

    return sum;
}

add(2, 5, 3) // 10
上一篇下一篇

猜你喜欢

热点阅读