TypeScript 函数类型 (二)

news/2024/8/27 8:48:38 标签: typescript, 前端

函数类型

函数有两种方式定义

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

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

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
}

类型推导

根据返回值类型推导

function f(a:string,b:string) {
    return a+b
}

在这里插入图片描述

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

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

在这里插入图片描述
入参数量可以比类型中的数量少,更具位置一一对应,但是不能多

函数返回类型

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

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

在这里插入图片描述

函数可选参数

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

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

在这里插入图片描述

函数剩余参数

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

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

在这里插入图片描述

获取类型的内置方法

  • typeof 获取变量类型
let person = {
    name: '123',
    age: 123
}
type PersonType = typeof person

在这里插入图片描述

  • keyof 获取索引类型只能查询类型
type PersonKeyType = keyof typeof person

在这里插入图片描述

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

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中的重载是伪重载,只是类型重载,不是逻辑重载

function toArray(value: string | number){
    if (typeof value ==='string') {
        return value.split('')
    }
    if (typeof value === 'number') {
        return value.toString().split('')
    }
}
let arr = toArray('123')

在这里插入图片描述


http://www.niftyadmin.cn/n/5558758.html

相关文章

c++ vector函数

一、vector 的初始化&#xff1a;可以有五种方式,举例说明如下&#xff1a; (1) vector<int> a(10); //定义了10个整型元素的向量。&#xff08;2&#xff09;vector<int> a(10,1); //定义了10个整型元素的向量,且给出每个元素的初值为1&#xff08;3&#xff09;v…

《绝区零》是一款什么类型的游戏,Mac电脑怎么玩《绝区零》苹果电脑玩游戏怎么样

米哈游的《绝区零》最近在网上爆火呀&#xff0c;不过很多人都想知道mac电脑能不能玩《绝区零》&#xff0c;今天麦麦就给大家介绍一下《绝区零》是一款什么样的游戏&#xff0c;Mac电脑怎么玩《绝区零》。 一、《绝区零》是一款什么样的游戏 《绝区零》是由上海米哈游自主研发…

卷积神经网络——LeNet——FashionMNIST

目录 一、文件结构二、model.py三、model_train.py四、model_test.py 一、文件结构 GitHub 二、model.py import torch from torch import nn from torchsummary import summaryclass LeNet(nn.Module):def __init__(self):super(LeNet,self).__init__()self.c1 nn.Conv2d(i…

用python写一个爬虫,爬取google中关于蛇的照片

为了爬取Google中关于蛇的照片&#xff0c;我们可以利用Python中的第三方库进行网页解析和HTTP请求。请注意&#xff0c;这种爬取行为可能违反Google的使用条款&#xff0c;因此建议在合法和允许的情况下使用。以下是一个基本的Python爬虫示例&#xff0c;使用Requests库发送HT…

SpringCache介绍

SpringCache是Spring提供的缓存框架。提供了基于注解的缓存功能。 SpringCache提供了一层抽象&#xff0c;底层可以切换不同的缓存实现&#xff08;只需要导入不同的Jar包即可&#xff09;&#xff0c;如EHCache&#xff0c;Caffeine&#xff0c;Redis。 2个重要依赖已经导入&a…

【Spark On Hive】—— 基于电商数据分析的项目实战

文章目录 Spark On Hive 详解一、项目配置1. 创建工程2. 配置文件3. 工程目录 二、代码实现2.1 Class SparkFactory2.2 Object SparkFactory Spark On Hive 详解 本文基于Spark重构基于Hive的电商数据分析的项目需求&#xff0c;在重构的同时对Spark On Hive的全流程进行详细的…

知识加油站

我的&#x1f351;宝店【码猿小铺】持续进行&#xff0c;其中有Linux/shell视频&#xff08;包含项目实操&#xff09;、新版ShardingJDBC分库分表视频&#xff08;包含项目实操&#xff09;、初中高级面试专栏、React全套视频&#xff08;包含项目实操&#xff09;、新版javes…

jail子系统里升级Ubuntu focal到jammy

Ubuntu focal是20.04 &#xff0c;jammy版本是22.04&#xff0c;本次的目的就是将FreeBSD jail子系统里的Ubuntu 从20.04升级到22.04 。这个focal 子系统是通过cbsd克隆得到的。使用CBSD克隆复制Ubuntu jail子系统环境-CSDN博客 do-release-upgrade升级没成功&#xff0c;用de…