美文网首页js css html
ES6 函数的扩展

ES6 函数的扩展

作者: Cherry丶小丸子 | 来源:发表于2023-02-22 16:53 被阅读0次
    函数参数的默认值

    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
    

    相关文章

      网友评论

        本文标题:ES6 函数的扩展

        本文链接:https://www.haomeiwen.com/subject/arqakdtx.html