TypeScript 函数类型 (二)

函数类型

函数有两种方式定义

  • function 关键字来定义函数
javascript 复制代码
function a(){}
  • 表达式定义(箭头函数的形式)
javascript 复制代码
const a=()=>{}

函数需要定义类型的有三个地方 入参返回值 以及 函数本身 的类型, 函数本身的类型常用于表达式定义的函数

javascript 复制代码
function sum(a:string,b:string):string{
    return a+b
}
let sum1 = (a:string,b:string): string => {
    return a+b
}

type sum1Type = (a:string,b:string)=> string
let sum2: sum1Type = (a:string,b:string): string => {
    return a+b
}

类型推导

根据返回值类型推导

javascript 复制代码
function f(a:string,b:string) {
    return a+b
}

根据上下文推导,根据位置来进行推导,也就是 x 对应入参 a 的类型,y对应b的类型,

javascript 复制代码
type ISum = (x:string,y:string)=> string;
let sum3:ISum = (a,b) => {
    return a+b
}


入参数量可以比类型中的数量少,更具位置一一对应,但是不能多

函数返回类型

函数返回类型可以为void,意思为不校验返回值,在某些时候函数有没有返回值是没有意义的。

javascript 复制代码
type ICallback = (a:string,b:number)=> void
function fn(callback:ICallback) {}
fn((a,b) => {
    return '1'
})

函数可选参数

在入参后面增加?,可以将这个入参变为可选,但是只能用在入参最后。

javascript 复制代码
let sum4 = (a:string,b:string,c?:string):string => {
    return a+b
}
sum4('3','7')

函数剩余参数

剩余运算符 ...,可以传入不指定数量的参数

javascript 复制代码
let total = (a:string,b:string,...rest:string[]): string => {
    return a+b+rest.join('')
}
total('1','2','3','4','5')

获取类型的内置方法

  • typeof 获取变量类型
javascript 复制代码
let person = {
    name: '123',
    age: 123
}
type PersonType = typeof person
  • keyof 获取索引类型只能查询类型
javascript 复制代码
type PersonKeyType = keyof typeof person

ts中this需要手动指定。默认是函数的第一个参数

javascript 复制代码
let person = {
    name: '123',
    age: 123
}
type PersonType = typeof person
type PersonKeyType = keyof typeof person
function getV(this: PersonType, key: PersonKeyType ) {
    return this[key]
}
let r = getV.call(person, "name")

函数重载

重载 根据不同的参数类型做不同处理,一般这个参数类型是有限的。ts中的重载是伪重载,只是类型重载,不是逻辑重载

javascript 复制代码
function toArray(value: string | number){
    if (typeof value ==='string') {
        return value.split('')
    }
    if (typeof value === 'number') {
        return value.toString().split('')
    }
}
let arr = toArray('123')
相关推荐
码事漫谈几秒前
解决 Anki 启动器下载错误的完整指南
前端
im_AMBER20 分钟前
Web 开发 27
前端·javascript·笔记·后端·学习·web
蓝胖子的多啦A梦1 小时前
低版本Chrome导致弹框无法滚动的解决方案
前端·css·html·chrome浏览器·版本不同造成问题·弹框页面无法滚动
玩代码1 小时前
vue项目安装chromedriver超时解决办法
前端·javascript·vue.js
訾博ZiBo1 小时前
React 状态管理中的循环更新陷阱与解决方案
前端
StarPrayers.1 小时前
旅行商问题(TSP)(2)(heuristics.py)(TSP 的两种贪心启发式算法实现)
前端·人工智能·python·算法·pycharm·启发式算法
一壶浊酒..2 小时前
ajax局部更新
前端·ajax·okhttp
DoraBigHead2 小时前
React 架构重生记:从递归地狱到时间切片
前端·javascript·react.js
彩旗工作室3 小时前
WordPress 本地开发环境完全指南:从零开始理解 Local by Flywhee
前端·wordpress·网站
iuuia3 小时前
02--CSS基础
前端·css