Ts中函数的使用

Posted 老张在线敲代码

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Ts中函数的使用相关的知识,希望对你有一定的参考价值。

函数

基本示例

和 JavaScript 一样,TypeScript 函数可以创建有名字的函数和匿名函数

// 命名函数
function add(x, y) 
  return x + y


// 匿名函数
let myAdd = function(x, y)  
  return x + y;

函数类型

function add(x: number, y: number): number 
  return x + y


let myAdd = function(x: number, y: number): number  
  return x + y

我们可以给每个参数添加类型之后再为函数本身添加返回值类型。TypeScript 能够根据返回语句自动推断出返回值类型。

书写完整函数类型

let myAdd2: (x: number, y: number) => number = 
function(x: number, y: number): number 
  return x + y

可选参数和默认参数

TypeScript 里的每个函数参数都是必须的, 简短地说,传递给一个函数的参数个数必须与函数期望的参数个数一致。

JavaScript 里,每个参数都是可选的,可传可不传。 没传参的时候,它的值就是 undefined。 在TypeScript
里我们可以在参数名旁使用 ? 实现可选参数的功能。

在 TypeScript 里,我们也可以为参数提供一个默认值当用户没有传递这个参数或传递的值是 undefined 时。 它们叫做有默认初始化值的参数。 让我们修改上例,把firstName 的默认值设置为 “A”。

function buildName(firstName: string='A', lastName?: string): string 
  if (lastName) 
    return firstName + '-' + lastName
   else 
    return firstName
  


console.log(buildName('C', 'D'))
console.log(buildName('C'))
console.log(buildName())

剩余参数

在 JavaScript 里,你可以使用 arguments 来访问所有传入的参数。

在ts中剩余参数会被当做个数不限的可选参数。 可以一个都没有,同样也可以有任意个。 编译器创建参数数组,名字是你在省略号( …)后面给定的名字,你可以在函数体内使用这个数组。

function info(x: string, ...args: string[]) 
  console.log(x, args)

info('abc', 'c', 'b', 'a')

函数重载

函数重载: 函数名相同, 而形参不同的多个函数

/* 
函数重载: 函数名相同, 而形参不同的多个函数
需求: 我们有一个add函数,它可以接收2个string类型的参数进行拼接,也可以接收2个number类型的参数进行相加 
*/

// 重载函数声明
function add (x: string, y: string): string
function add (x: number, y: number): number

// 定义函数实现
function add(x: string | number, y: string | number): string | number 
  // 在实现上我们要注意严格判断两个参数的类型是否相等,而不能简单的写一个 x + y
  if (typeof x === 'string' && typeof y === 'string') 
    return x + y
   else if (typeof x === 'number' && typeof y === 'number') 
    return x + y
  


console.log(add(1, 2))
console.log(add('a', 'b'))
// console.log(add(1, 'a')) // error

以上是关于Ts中函数的使用的主要内容,如果未能解决你的问题,请参考以下文章

为啥 TS 中的泛型接口不能正确推断类型?

TS基础

如何在 TypeScript 3+ 中正确键入通用元组剩余参数?

TS-- 类型推论类型兼容性高级类型

TypeScript类型检查机制

打字稿推断出不正确的类型:TS2339 属性“选定”在类型“字符串”上不存在