美文网首页
带你读书之“红宝书”:第十章 函数④

带你读书之“红宝书”:第十章 函数④

作者: 前端不许笑 | 来源:发表于2022-02-22 23:06 被阅读0次

「这是我参与2022首次更文挑战的第34天,活动详情查看:2022首次更文挑战

写在前头

大多数小伙伴看技术书籍都会用“啃”来描述读书的直观感受,当然我也是一个前端小白,白的透明那种,但是我在读技术书籍感觉到“啃”的时候,我希望把我啃红宝书第四版的过程的想法,总结带给大家,以供后来者能够更快上手。

注: 本文由于作者水平原因,如有错误之处,恳请大家指正,另外随着学习的深入,体会的加深,我会不断回来更新,修改这类文章。

思维导图

image.png

简述

函数这一章其实在有一定的编程基础,比如学过一点c语言就很好读下去。整体还是易读板块。

10.6参数扩展与收集

image.png

10.6.1扩展参数

  • 累加

    迭代arguments对象

    let values = [1, 2, 3, 4];
    function getSum() {
    return Array.from(arguments).reduce((pre, cur) => pre + cur, 0);
    }
    

    ②apply()

     console.log(getSum.apply(null, values)); // 10
    

    ③扩展操作符

    使用扩展操作符可以把数组逐个元素传入函数。将可迭代对象拆分。将迭代拆分的返回值单独输入。

    扩展操作符是“...”

        let values = [1, 2, 3, 4];
      console.log(getSum(...values)); // 10
    

    使用扩展操作符时候,依然可以和其他参数混合使用。前后都可以添加参数。

        let values = [1, 2, 3, 4];
      console.log(getSum(-1,...values, 2)); // 11
    

    还可以使用多个扩展符

        let values = [1, 2, 3, 4];
      console.log(getSum(...values, ...[5,6,7])); // 28
    
  • arguments对象与扩展操作符

arguments对象不知道是否使用了扩展操作符,但是他只会老老实实地把使用扩展符传入的参数依次保存到“数组”。

  • 命名参数

在普通函数,箭头函数中可以使用扩展操作符用于命名参数,和默认参数结合使用。

 let values = [1, 2, 3, 4];
function countArguments() {
console.log(arguments.length);
}
countArguments(-1, ...values); // 5
countArguments(...values, 5); // 5
countArguments(-1, ...values, 5); // 6
countArguments(...values, ...[5, 6, 7]); // 7

10.6.2收集参数

  • 使用扩展操作符传参

在构思函数定义时,可以使用扩展操作符把不同长度的独立参数组合为一个数组。类似arguments 对象的构造机制,只收集参数会得到一个 Array 实例。

  • 收集参数前面有命名参数

    必须把扩展操作符放在末尾。

  • 箭头函数

    ①不支持 arguments 对象

    ②支持收集参数的定义方式

  • arguments对象与收集参数

    2者并没有什么直接关系,不会感染arguments对象存入传入的参数。

    使用收集参数并不影响 arguments 对象,它仍然反映调用时传给函数的参数

相关文章

网友评论

      本文标题:带你读书之“红宝书”:第十章 函数④

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