TS的函数如何定义类型

如何接受arguments参数
复制代码
function add(...args: string[]) {

    let list4: IArguments = arguments;

}

add('1', '2')
自定义一个args
复制代码
interface A1 {

    callee: Function,

    length: number,

    [index: number]: any

}

function adds(...args: string[]) {

    let list4: A1 = arguments;

}

adds('1', '2')
多个参数
复制代码
function add1(a: number, b: number): number {

    return a + b;

}

const add2 = (a: number, b: number): number => {

    return a + b;

}
默认值
复制代码
const add3 = (a: number = 10, b: number = 15): number => {

    return a + b;

}
可选参数
复制代码
const add4 = (a?: number, b?: number): void => {

}
定义一个对象参数
复制代码
interface User {

    name: string,

    age: number

}

function getName(data: User): User {

    return data;

}
定义this参数

//ts 可以定义this 必须是第一个参数

复制代码
interface Obj {

    list: number[],

    add: (this: Obj, num: number) => void

}

let obj: Obj = {

    list: [1, 2, 3, 4],

    add(this: Obj, num: number) {

        this.list.push(num);

        console.log(this.list)

    }

}
相关推荐
SleepyZone4 分钟前
Cline 源码浅析 - 从输入到输出
前端·ai编程·cline
Struggler2818 分钟前
pinia-基于monorepo的项目结构管理
前端
Struggler28112 分钟前
SSE的使用
前端
用户58061393930019 分钟前
前端文件下载实现深度解析:Blob与ObjectURL的完美协作
前端
Lin866622 分钟前
Vue 3 + TypeScript 组件类型推断失败问题完整解决方案
前端
coding随想22 分钟前
从零开始:前端开发者的SEO优化入门与实战
前端
前端工作日常25 分钟前
我理解的JSBridge
前端
Au_ust25 分钟前
前端模块化
前端
顺丰同城前端技术团队25 分钟前
还不会用 Charles?最后一遍了啊!
前端
BUG收容所所长26 分钟前
二分查找的「左右为难」:如何优雅地找到数组中元素的首尾位置
前端·javascript·算法