TypeScript的函数

// 类型别名
type ISum = (x: number, y: number) => number
// 应用如下:
let sum: ISum = (a, b) => a + b
console.log(sum(3, 2));

 

复制代码
//函数重载
function fn(name: string): string;
function fn(age: number): number;
function fn(nameorage: any): any {
    if (typeof nameorage == "string") {
        return "姓名:" + nameorage;
    } else if (typeof nameorage == "number") {
        return "年龄:" + nameorage
    }
}
// 姓名:张培跃
console.log(fn("张2"));
// 年龄:18
console.log(fn(666));
复制代码

 

复制代码
//======函数重载====反转数字或字符串
function reverse(num: number): number;
function reverse(str: string): string;
function reverse(val: any): any {
  if (typeof val === 'number') {
    return Number(val.toString().split('').reverse().join(''))
  } else if (typeof val === 'string') {
    return val.split('').reverse().join('')
  }
  return false
}

console.log(reverse(123456))  // 654321
console.log(reverse('sina'))  // 'anis'
复制代码

 

复制代码
//函数的 剩余参数
function sum2(num1: number, ...rest: number[]): number {
    interface ITotal {
      (pre: number, cur: number): number;
    }
    const handle: ITotal = (pre, cur) => pre + cur
    return rest.reduce(handle, num1)
  }
  
console.log(sum2(1, 2, 3, 4, 5, 6, 7)); // 28
复制代码

 

//====缺省的第1个参数,this 指针
function fun3(this:any, para1:number,para2:number)
{
    console.log(para1);
    console.log(para2);
}

fun3(1,2);//1,2

 

posted @   He_LiangLiang  阅读(199)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示