typescript函数

typescript函数的隐式定义

在typescript中的函数并不需要刻意去定义,比如我们实现一个加法函数:

const add = (a:number, b:number) => {a + b}

这种方式没有显示的去定义一个函数,但是typescript是可以检测到的

typescript函数的显式定义

在变量后面加冒号与类型的定义,括号里的(a:number, b:number)为参数类型,而通过=> 来链接与返回值,最后则是返回值的类型。

const add:(a:number, b:number) => number = (a:number, b:number) => a +  b

函数的参数

  • 可选参数
    一个函数的参数可能是不存在的,可以使用?来定义这种情况
const add (a:number, b?:number) => a + (b?b:0)

参数b有number与undefined两种可能。

  • 默认参数
    与javascript类似。
const add = (a:number, b= 0) => a + b
  • 剩余参数
    与javascript类似
const add = (a:number ,...rest:number[]) => rest.reduce(((a,b)=>a + b ),a)

重载

重载(overloading) 是在一个类里面,方法名字相同,而参数不同。返回类型可以相同也可以不同。
每个重载的方法(或者构造函数)都必须有一个独一无二的参数类型列表。

  • typescript重载的实现
// 重载
interface Direction {
  top: number,
  bottom?: number,
  left?: number,
  right?: number
}
function assigned(all: number): Direction
function assigned(topAndBottom: number, leftAndRight: number): Direction
function assigned(top: number, right: number, bottom: number, left: number): Direction

function assigned (a: number, b?: number, c?: number, d?: number) {
  if (b === undefined && c === undefined && d === undefined) {
    b = c = d = a
  } else if (c === undefined && d === undefined) {
    c = a
    d = b
  }
  return {
    top: a,
    right: b,
    bottom: c,
    left: d
  }
}

assigned(1)
assigned(1,2)
assigned(1,2,3)
assigned(1,2,3,4)
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 函数是JavaScript应用程序的基础。 它帮助你实现抽象层,模拟类,信息隐藏和模块。 在TypeScript里...
    2o壹9阅读 3,707评论 0 49
  • 1. 函数声明 1.1 函数声明法 1.2 函数表达式 1.3 匿名函数 TypeScript中的函数也是...
    浅忆_0810阅读 2,425评论 0 1
  • TypeScript提供了函数重载的功能,它可以支持多种形式的参数类型,返回相同或者不同类型的结果 为什么提供重载...
    是苏菇凉呀阅读 3,321评论 0 1
  • 介绍 函数是 JavaScript 应用程序的基础,它帮助你实现抽象层、模拟类、信息隐藏和模块。在 TypeScr...
    24KBING阅读 2,823评论 0 0
  • 日期: 2019 年 9 月 3 日 typescript 函数 具名函数与匿名函数 和JavaScript一样,...
    五十岚色叶阅读 2,642评论 0 2