函数扩展

函数的类型

function fn(name: string, age: number): string {
    return `${name} - ${age}`
}

fn(mk, 18)

函数的可选参数

function fn(name: string, age?: number): string {
    return `${name} - ${age ?? 18}`
}

fn(mk)

函数参数的默认值

function fn(name: string, age: number = 18): string {
    return `${name} - ${age}`
}

fn(mk)

接口定义函数

interface Add {
    (a: number, b: number): number
}

const fn: Add = (a: number, b: number): number => {
    return a + b
}

fn(1, 2)

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]

fn(a,'2','3','4')

函数重载

// 重载是方法名字相同,而参数不同,返回类型可以相同也可以不同。
// 如果参数类型不同,则参数类型应设置为 any。
// 参数数量不同你可以将不同的参数设置为可选。

function fn(p: number): void
function fn(p: string, p2: number): void
function fn(p: any, p2?: any): void {
    console.log(p)
    console.log(p2)
}

fn(1)
fn('1', 2)
贡献者: mankueng