zoukankan      html  css  js  c++  java
  • [TypeScript] Overload a Function with TypeScript’s Overload Signatures

    Some functions may have different return types depending on the types of the arguments with which they’re invoked. Using TypeScript’s function overloads, you can create an overload for each allowed combination of parameter and return types. This way, all type-correct signatures of a function are encoded in the type system and can be surfaced by the TypeScript Language Service within your editor.

    /**
     * Reverses the given string.
     * @param string The string to reverse.
     */
    function reverse(string: string): string;
    
    /**
     * Reverses the given array.
     * @param array The array to reverse.
     */
    function reverse<T>(array: T[]): T[];
    
    function reverse(stringOrArray: string | any[]) {
        return typeof stringOrArray === "string" 
        ? [...stringOrArray].reverse().join("") 
        : stringOrArray.slice().reverse();
    }
    
    // [ts] const reversedString: string 
    const reversedString = reverse("TypeScript");
    // [ts] const reversedArray: number[]
    const reversedArray = reverse([4, 8, 15, 16, 23, 42]);
    console.log(reversedString)
    console.log(reversedArray)

     

  • 相关阅读:
    Dictionary集合 字典
    装箱和拆箱
    List< >泛型集合
    Hashtable 键值对集合
    File 类 的基本操作
    简体转换繁体
    ArrayList集合长度的问题
    ArrayList  集合
    里式转换
    字符串中常用的方法
  • 原文地址:https://www.cnblogs.com/Answer1215/p/7815909.html
Copyright © 2011-2022 走看看