TypeScript学习笔记(八)函数的类型
函数声明
- 需要对函数的输入和输出进行限制。
- 输入多余的(或者少于要求的)参数,是不被允许的
1 | function sum(x: number, y: number): number { |
函数表达式
- 在 TypeScript 的类型定义中,=> 用来表示函数的定义,左边是输入类型,需要用括号括起来,右边是输出类型。
1 | let mySum: (x: number, y: number) => number = function (x: number, y: number): number { |
用接口定义函数的形状
- 采用函数表达式|接口定义函数的方式时,对等号左侧进行类型限制,可以保证以后对函数名赋值时保证参数个数、参数类型、返回值类型不变。
1 | interface SearchFunc { |
可选参数
- 用 ? 表示可选的参数。
- 可选参数后面不允许再出现必需参数。
1 | function buildName(firstName: string, lastName?: string) { |
参数默认值
- TypeScript 会将添加了默认值的参数识别为可选参数:
1 | function buildName(firstName: string, lastName: string = 'Cat') { |
剩余参数
- 使用
...rest
的方式获取函数中的剩余参数(rest 参数)。
1 | function push(array, ...items) { |
重载
- 重载允许一个函数接受不同数量或类型的参数时,作出不同的处理。
- 定义多个重名函数来实现重载。
1 | // 实现一个函数 reverse,输入数字 123 的时候,输出反转的数字 321,输入字符串 'hello' 的时候,输出反转的字符串 'olleh'。 |
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 姚永坤的小窝!
评论