美文网首页
数组的类型,函数的类型

数组的类型,函数的类型

作者: 不落05 | 来源:发表于2023-05-12 18:15 被阅读0次

    在 TypeScript 中,数组类型有多种定义方式,比较灵活。

    let fibonacci: number[] = [1, 1, 2, 3, 5];
    // 定义了数字类型的数组,对于push,splice,unshift可插入新值的方法也存在同样的约束
    
    

    数组泛型

    let fibonacci: Array<number> = [1, 1, 2, 3, 5];
    
    

    用接口表示数组

    interface NumberArray {
        [index: number]: number;
    }
    let fibonacci: NumberArray = [1, 1, 2, 3, 5];
    

    类数组

    function sum() {
        let args: {
            [index: number]: number;
            length: number;
            callee: Function;
        } = arguments;
    }
    

    事实上常用的类数组都有自己的接口定义,如 IArguments, NodeList, HTMLCollection等:

    any 在数组中的应用

    一个比较常见的做法是,用 any 表示数组中允许出现任意类型:

    let list: any[] = ['xcatliu', 25, { website: 'http://xcatliu.com' }];
    
    

    元组

    数组合并了相同类型的对象,而元组(Tuple)合并了不同类型的对象。

    let tom: [string, number] = ['Tom', 25];
    

    直接对元组类型的变量进行初始化或者赋值的时候,需要提供所有元组类型中指定的项。
    当添加越界的元素时,它的类型会被限制为元组中每个类型的联合类型。

     


     

    函数声明

    一个函数有输入和输出,要在 TypeScript 中对其进行约束,需要把输入和输出都考虑到,其中函数声明的类型定义较简单:

    function sum(x: number, y: number): number {
        return x + y;
    }
    

    函数表达式

    let sum= function (x: number, y: number): number {
        return x + y;
    };
    
    let mySum: (x: number, y: number) => number = function (x: number, y: number): number {
        return x + y;
    };
    

    注意不要混淆了 TypeScript 中的 => 和 ES6 中的 =>。

    在 TypeScript 的类型定义中,=> 用来表示函数的定义,左边是输入类型,需要用括号括起来,右边是输出类型。

    用接口定义函数的形状

    interface SearchFunc {
        (source: string, subString: string): boolean;
    }
    
    let mySearch: SearchFunc;
    mySearch = function(source: string, subString: string) {
        return source.search(subString) !== -1;
    }
    

    可选参数

    需要注意的是,可选参数必须接在必需参数后面。换句话说,可选参数后面不允许再出现必需参数了

    function buildName(firstName: string, lastName?: string) {
        if (lastName) {
            return firstName + ' ' + lastName;
        } else {
            return firstName;
        }
    }
    let tomcat = buildName('Tom', 'Cat');
    let tom = buildName('Tom');
    

    参数默认值

    在 ES6 中,我们允许给函数的参数添加默认值,TypeScript 会将添加了默认值的参数识别为可选参数,此时就不受「可选参数必须接在必需参数后面」的限制了。

    剩余参数

    同es6相同,rest放在最后

    function push(array: any[], ...items: any[]) {
        items.forEach(function(item) {
            array.push(item);
        });
    }
    
    let a = [];
    push(a, 1, 2, 3);
    

    重载

    function reverse(x: number): number;
    function reverse(x: string): string;
    function reverse(x: number | string): number | string | void {
        if (typeof x === 'number') {
            return Number(x.toString().split('').reverse().join(''));
        } else if (typeof x === 'string') {
            return x.split('').reverse().join('');
        }
    }
    

    注意,TypeScript 会优先从最前面的函数定义开始匹配,所以多个函数定义如果有包含关系,需要优先把精确的定义写在前面。

    相关文章

      网友评论

          本文标题:数组的类型,函数的类型

          本文链接:https://www.haomeiwen.com/subject/gxarsdtx.html