首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

正确使用typescript泛型

基础概念

TypeScript 泛型(Generics)是一种允许在定义函数、接口或类时,不预先指定具体的类型,而是在使用时再指定类型的一种编程技巧。泛型提供了一种方式,使得代码更加灵活、可重用,并且能够提高类型安全性。

优势

  1. 类型安全:泛型允许在编译时检查类型,减少运行时的类型错误。
  2. 代码复用:通过泛型,可以编写适用于多种类型的通用代码,而不需要为每种类型都编写特定的实现。
  3. 提高可读性:泛型使得代码更加清晰,易于理解和维护。

类型

TypeScript 泛型主要有以下几种类型:

  1. 泛型函数:定义一个可以接受不同类型参数的函数。
  2. 泛型接口:定义一个可以包含不同类型属性和方法的接口。
  3. 泛型类:定义一个可以包含不同类型属性和方法的类。

应用场景

泛型在以下场景中非常有用:

  1. 集合类:如数组、列表等,可以定义一个通用的集合类,支持不同类型的数据。
  2. API 设计:在编写 API 时,可以使用泛型来定义返回值和参数类型,使得 API 更加灵活。
  3. 工具函数:编写可以处理多种类型的工具函数,如排序、过滤等。

示例代码

泛型函数

代码语言:txt
复制
function identity<T>(arg: T): T {
    return arg;
}

let output = identity<string>("myString");
let output2 = identity<number>(123);

泛型接口

代码语言:txt
复制
interface GenericIdentityFn<T> {
    (arg: T): T;
}

function identity<T>(arg: T): T {
    return arg;
}

let myIdentity: GenericIdentityFn<number> = identity;

泛型类

代码语言:txt
复制
class GenericNumber<T> {
    zeroValue: T;
    add: (x: T, y: T) => T;
}

let myGenericNumber = new GenericNumber<number>();
myGenericNumber.zeroValue = 0;
myGenericNumber.add = function(x, y) { return x + y; };

常见问题及解决方法

问题:类型推断失败

原因:在使用泛型时,TypeScript 编译器可能无法推断出具体的类型。

解决方法:显式指定类型参数。

代码语言:txt
复制
let output = identity<string>("myString"); // 显式指定类型参数

问题:类型不匹配

原因:在使用泛型时,传入的类型与预期类型不匹配。

解决方法:检查传入的参数类型,并确保其与泛型定义的类型一致。

代码语言:txt
复制
function add<T extends number>(x: T, y: T): T {
    return x + y;
}

let result = add(1, 2); // 正确
let result2 = add("1", "2"); // 错误,类型不匹配

问题:泛型约束

原因:有时需要对泛型的类型进行约束,以确保传入的类型满足某些条件。

解决方法:使用 extends 关键字对泛型进行约束。

代码语言:txt
复制
interface Lengthwise {
    length: number;
}

function loggingIdentity<T extends Lengthwise>(arg: T): T {
    console.log(arg.length); // 现在我们知道arg具有length属性
    return arg;
}

参考链接

通过以上内容,你应该能够更好地理解 TypeScript 泛型的基础概念、优势、类型、应用场景以及常见问题的解决方法。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

TypeScript

TypeScript 中,(Generics)是一种用于创建可重用的组件的强大工具。允许在函数、类和接口中使用类型参数,使得这些组件能够适应多种数据类型,提高代码的灵活性和可重用性。...类是一种具有类型参数的类。通过在类名后面使用尖括号 来定义类型参数,并在类的属性、方法或构造函数中使用类型参数,可以创建可适用于多种类型的类。...接口接口是一种具有类型参数的接口。通过在接口名后面使用尖括号 来定义类型参数,并在接口的属性或方法中使用类型参数,可以定义适用于多种类型的接口。...约束有时候我们希望类型参数具有某些特定的属性或方法。为了达到这个目的,可以使用约束(Generic Constraints)。...然后,我们定义了一个型函数 getLength,该函数接受一个类型参数 T,并使用约束 T extends Lengthy,表示 T 必须具有 Lengthy 接口中定义的属性。

50220
  • TypeScript -

    尖括号内的变量名并不是固定的,可以自定义,一般都是大写 类实例化传入的类型,可以在整个作用域中使用类型,但要注意的是类的静态属性无法使用类型 class Handsome<...有时候我们希望参数符合某些规则时,你应该想到使用约束来解决问题。 基于接口约束 使用约束来对 formatArr 做一些改造,改造后的函数功能为对传入的参数进行切片,返回除第一项的数据。...参数的默认类型 在 TypeScript 2.3 以后,我们可以为中的类型参数指定默认类型。当使用时没有在代码中直接指定类型参数,从实际值参数中也无法推测出时,这个默认类型就会起作用。...,不难发现的强大,可变的类型变量和约束为 TypeScript 的类型推导都提供了很大的贡献。...类型是 TypeScript 的核心,也是它的魅力所在。理解并应用,可以使我们的 TypeScript 水平更上一层楼。

    1.2K10

    TypeScript

    在像C#和Java这样的语言中,可以使用来创建可重用的组件,一个组件可以支持多种类型的数据。 这样用户就可以以自己的数据类型来使用组件。 ——摘自官方文档为什么要引入的概念呢?...我们在定义函数、接口或类的时候,不预先指定具体类型,而是在使用的时候再指定类型,先站住位置再说,保证了输入输出保持一致的问题。这里举个例子说明为什么要使用。...1、常用的变量T(Type) :代表类型,定义时通常作为第一个类型变量名称K(Key):表示对象中的键类型U:表示对象中的键类型V(Value):表示对象中的值类型E(Element):表示元素或者节点类型...(val:T):T { console.log(val.length) return val}4、约束我们之间使用属性方法,但是不知道类型就会报错,所以需要对参数类型进行约束...result({name:"zhangsan"})如果不对变量类型进行约束的话,还是会报错滴,如下:5、工具类型后续更新工具类型 我正在参与2023腾讯技术创作特训营第三期有奖征文,组队打卡瓜分大奖

    14700

    TypeScript应用

    概念: 程序设计(generic programming)是程序设计语言的一种风格或范式。允许程序员在强类型程序设计语言中编写代码时使用一些以后才指定的类型,在实例化时作为参数指明这些类型。...应用: 场景:在做前后端交互数据接口统一返回格式定义的场景来进行的实战训练。...我们看一看应用后有什么变化吧。 对类进行升级-应用: 1....:(因为类型不确定只能是any) 配置类型后的类型提示: 3....) } class GoodsResponse extends BaseResponse { // 实现组装数据函数(模拟使用) } 结语: 的应用使我们的程序在设计过程中对结构进行抽象但不指明具体类的类型

    48820

    TypeScript-

    概述在编写代码的时候我们既要考虑代码的 健壮性, 又要考虑代码的 灵活性 和 可重用性通过 TS 的静态检测能让我们编写的代码变得更加 健壮, 但是在变得健壮的同时却丢失了 灵活性 和 可重用性所以为了解决这个问题...TS 推出了 的概念通过 不仅可以让我们的代码变得更加 健壮, 还能让我们的代码在变得 健壮 的同时保持 灵活性 和 可重用性还是和之前一样的套路,利用一个需求来引出没有使用的弊端,需求...=> [3, 3, 3]let res = arr.map(item => item.length);console.log(res);那么如上的需求就看到这里,接下来再看一个需求利用这个需求来引出...};let arr = getArray('abc');let res = arr.map(item => item.length);console.log(res);如上代码我们指定的类型为...string 所以调用 .length 就不会报错这是正常的,如果我们将的类型改为 number 在来看的话编译器就会直接报错:图片注意点具体的类型可以不指定, 如果没有指定, 那么就会根据我们传递的参数自动推导出来

    15710

    TypeScript使用使用指南

    让我们探索一些 TypeScript 项目中的的实际应用。 函数中使用 其中一个使用使用场景是函数创建。...通过这个方法,这能函数能放心使用将会存在的传递过来的参数的 length 属性。 使用 keyof TypeScript 中 keyof 操作符可以在中结合使用,来确保属性名的类型安全。...实用类型 utility TypeScript 包含系列实用类型,可以更轻松地使用以各种形式转换类型。...避免中常见的错误 使用中一个常见的错误是假设一个有确定的属性或者方法而没正确约束。这个会导致运行时错误。当我们希望一个类型变量有特定的行为,要时刻记得定义合适的约束。...请记得,在深思熟虑后,将它整合到我们的开发流程中,并享受正确使用它们所产生的类型安全和可维护性代码的乐趣。

    15010

    _TypeScript笔记6

    。...带类型参数的接口叫接口,例如可以用接口来描述一个型函数: interface GenericIdentityFn { (arg: T): T; } 还有一种非常相像的形式: interface...idArray: (...s: number[]) => s, }; 接口级的类型参数有这种约束作用,成员级的则没有(仅作用于该成员) 五.类 同样,带类型参数的类叫类,例如: class...六.约束 类型参数太“”(any and all)了,在一些场景下,可能想要加以约束,例如: interface Lengthwise { length: number; }function loggingIdentity...另一个典型的场景是工厂方法,例如: // 要求构造函数c必须返回同一类(或子类)的实例 function create(c: {new(): T; }): T { return new c(); } 此外,还可以在约束中使用类型参数

    1.1K30

    TypeScript基础(五)

    为了提高代码的复用性和灵活性,TypeScript引入了的概念。可以让我们在定义函数、类或接口时,不预先指定具体的类型,而是在使用时再指定类型。...本文将详细介绍TypeScript使用方法和技巧。概念--是一种参数化类型的方式,它可以用来创建可重用的组件。...接口中使用接口可以使用来定义灵活的类型。可以通过在接口名后面使用尖括号()来定义参数,并在接口定义中使用该参数。...类中使用类可以使用来定义灵活的属性和方法。可以通过在类名后面使用尖括号()来定义参数,并在类定义中使用该参数。...TypeScript中非常重要的特性之一,它可以让我们在定义函数、类或接口时不预先指定具体的类型,而是在使用时再指定类型。

    32930

    TypeScript型函数、类、接口,约束,一文读懂

    最近在学TypeScript,然后整理了一下关于TypeScript的一些笔记。...的定义(generic type 或者 generics) TypeScript语言中的一种特性。 是程序设计语言的一种特性。是一种参数化类型。 ...在使用过程中,操作的数据类型会根据传入的类型实参来确定 可以用在 类、接口、方法中,分别被称为 类、接口、方法。...类和方法同时具备 通用性、类型安全和性能 ,是非类和非方法无法具备的 优势:高性能的变成方式、达到代码复用、提高代码通用性、 使用的是类型参数(变量),它是一种特殊的变量,代表的是类型而不是值...Interface 接口名{ //属性和方法签名 } Interface 接口名{ //属性和方法签名 } 共同点: 必须使用括起参数 T , 跟在 函数名||类名||接口名

    2.4K30

    TypeScript系列教程六《

    在像C#和Java这样的语言中,可以使用来创建可重用的组件,一个组件可以支持多种类型的数据。 这样用户就可以以自己的数据类型来使用组件。...} let myIdentity: (arg: T) => T = identity; 我们也可以使用不同的参数名,只要在数量上和使用方式上能对应上就可以。...注意,无法创建枚举和命名空间。 类 ---- 类看上去与接口差不多。 使用( )括起类型,跟在类名后面。...类指的是实例部分的类型,所以类的静态属性不能使用这个类型。 约束 ---- 你应该会记得之前的一个例子,我们有时候想操作某类型的一组值,并且我们知道这组值具有什么样的属性。...在约束里使用类类型 在TypeScript使用创建工厂函数时,需要引用构造函数的类类型。

    92310
    领券