当前位置: 首页 > article >正文

学习TypeScrip5(函数扩展)

函数的类型


注意,参数不能多传,也不能少传 必须按照约定的类型来

const fn = (name: string, age:number): string => {
    return name + age
}
fn('张三',18)


函数的可选参数?

通过?表示该参数为可选参数

const fn = (name: string, age?:number): string => {
    return name + age
}
fn('张三')


函数参数的默认值

const fn = (name: string = "我是默认值"): string => {
    return name
}
fn()


接口定义函数

定义参数 num 和 num2  :后面定义返回值的类型

interface Add {
    (num:  number, num2: number): number
}
 
const fn: Add = (num: number, num2: number): number => {
    return num + num2
}
fn(5, 5)
 
 
interface User{
    name: string;
    age: number;
}
function getUserInfo(user: User): User {
  return user
}


定义剩余参数

const fn = (array:number[],...items:any[]):any[] => {
       console.log(array,items)
       return items
}
 
let a:number[] = [1,2,3]
 
fn(a,'4','5','6')


函数重载

重载是方法名字相同,而参数不同,返回类型可以相同也可以不同。

如果参数类型不同,则参数类型应设置为 any

参数数量不同你可以将不同的参数设置为可选。

function fn(params: number): void
 
function fn(params: string, params2: number): void
 
function fn(params: any, params2?: any): void {
 
    console.log(params)
 
    console.log(params2)
 
}
 
 
 
fn(123)
 
fn('123',456)

http://www.kler.cn/a/155757.html

相关文章:

  • 【Linux】-学习笔记03
  • Linux 系统管理和监控命令---- auditctl命令
  • android dvr黑屏
  • [CKS] K8S ServiceAccount Set Up
  • Qt 获取当前系统中连接的所有USB设备的信息 libudev版
  • group_concat配置影响程序出bug
  • 数据结构之堆排序以及Top-k问题详细解析
  • SSM框架(三):SpringMVC
  • 【智能家居】四、网络服务器线程控制功能点
  • (一)WtBtRunner回测大体流程
  • [数据库]阿里云postgres数据库备份恢复
  • 30岁左右的简历模板精选7篇
  • Redis常见类型
  • 【c语言:常用字符串函数与内存函数的使用与实现】
  • 计组-指令周期、机器周期、时钟周期以及其它的各种周期
  • 使用单体锁和分布式锁解决超卖问题
  • MYSQL报错 [ERROR] InnoDB: Unable to create temporary file; errno: 0
  • WPF实战项目十九(客户端):修改RestSharp的引用
  • 【Docker】容器数据持久化及容器互联
  • ThinkPHP的方法接收json数据问题
  • 【数据挖掘】国科大刘莹老师数据挖掘课程作业 —— 第三次作业
  • Vue3中teleport如何使用
  • 详解Spring对Mybatis等持久化框架的整合
  • LeetCode - 100. 相同的树 (C语言,二叉树,配图,简单)
  • 代理模式介绍(静态代理、jdk动态代理、cglib代理)
  • 栈和队列的OJ题——14.用栈实现队列