Skip to content

函数扩展

函数的类型

ts
//注意,参数不能多传,也不能少传 必须按照约定的类型来
const fn = (name: string, age: number): string => {
  return name + age;
};
fn('张三', 18);

函数的可选参数?

ts
//通过?表示该参数为可选参数
const fn = (name: string, age?: number): string => {
  return name + age;
};
fn('张三');

函数参数的默认值

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

接口定义函数

ts
//定义参数 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;
}

定义剩余参数

ts
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。

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

在 TypeScript 中,函数重载的语法需要共用同一个函数实现大括号,这是 TypeScript 特有的语法规范,不能像 Java 的方法重载一样分开写。

下述方法中前两个是重载签名,最后一个才是函数实现。

ts
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);

Keep Reading, Keep Writing, Keep Coding