Typescript学习9 ( 泛型 | 泛型约束 )

一、泛型
1.类型不同,实现的功能是一样的,这时候我们就可以使用泛型来优化

函数泛型

function num(a: number, b: number): Array<number> {
    return [a, b]
}
function str(a: string, b: string): Array<string> {
    return [a, b]
}
2.泛型优化,函数后<>里可以通过一个占位符来定义泛型,也就是动态类型
function test<T>(a: T, b: T): Array<T>{ //占位符可以为任意字符
    return [a,b]
}
test(1, 2) //泛型可以自动推断出类型
test('1','2')
3.泛型可以使用不同类型参数名来对应不同的类型,数量也要对应上
function test<T, U>(a: T, b: U): Array<T | U> {
    return [a, b]
}
test(false, 1)
4.定义泛型接口
interface test<T> {
    msg: T
}
let message: test<string> = {
    msg: '123'
}

5.type泛型

type A<T> = T //任何类型都可以
let num: A<number> = 1 
let str: A<string> = 'sss'
let nul: A<null> = null 
6.泛型应用场景实例
// 封装axios
const axios = {
    get<T>(url: string): Promise<T> { //返回promise泛型
        return new Promise((resolve, reject) => {
            let xhr: XMLHttpRequest = new XMLHttpRequest()
            xhr.open('GET', url)
            xhr.onreadystatechange = () => { //检测状态变化
                if (xhr.readyState == 4 && xhr.status == 200) {
                    resolve(JSON.parse(xhr.responseText))
                }
            }
            xhr.send(null)
        })
    }
}
interface A {
    message: string,
    code: number
}
axios.get<A>('./index,json').then(res => {
    console.log(res.code);
})
二、泛型约束
1.泛型 extends 类型 ,泛型约束用来约束泛型的类型

数字类型

function add<T extends number>(a: T, b: T) {
    return a + b
}
add(1, 2)

字符串类型

function len<T extends string>(a: T) {
    return a.length
}
len('111')

接口类型

interface len{
    length:number
}
function fn<T extends len>(a: T) {
    return a.length
}
fn('111')
2.keyof 泛型,可以约束为对象的属性的联合类型
let obj = {
    name: '小胖',
    age: 18
}
//此时key的类型约束为 name|age 类型
function get<T extends Object, K extends keyof T>(obj: T, key: K) {
    return obj[key]
}
get(obj, "name")

3.泛型类

声明方法:名称后面定义<类型> ,使用的时候确定类型 new Sub<类型>()

class Sub<T>{
    arr: T[] = [];
    add(a: T): T[] {
        return [a]
    }
}
let s = new Sub<number>()
s.arr = [1, 2, 3]
s.add(123)
let str = new Sub<string>()
str.arr = ['1', '2', '3']
str.add('123')
  • 7
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TypeScript中,泛型是一种用于创建可以多种类型上工作的可重用代码的技术。使用泛型可以增强代码的灵活性和类型安全性。 要使用泛型,可以在函数、类或接口的定义中使用尖括号(<>)来指定泛型参数。例如,以下是一个使用泛型的简单示例: ```typescript function identity<T>(arg: T): T { return arg; } let result = identity<number>(5); console.log(result); // 输出:5 ``` 在上面的例子中,`identity`函数使用了一个泛型参数`T`,它表示函数的参数和返回值的类型是一致的。我们在调用`identity`函数时,显式指定了泛型参数为`number`,因此返回值的类型为`number`。 另外,还可以使用泛型约束来限制泛型参数的类型。例如,如果希望泛型参数必须具有某种特定属性,可以使用泛型约束来实现: ```typescript interface HasLength { length: number; } function printLength<T extends HasLength>(arg: T): void { console.log(arg.length); } printLength("Hello"); // 输出:5 printLength([1, 2, 3]); // 输出:3 printLength({ length: 10 }); // 输出:10 ``` 在上述示例中,`printLength`函数使用了一个泛型约束`T extends HasLength`,它表示泛型参数`T`必须具有`length`属性。因此,我们可以传递包含`length`属性的字符串、数组或对象作为参数,函数会打印出其长度。 通过使用泛型,我们可以编写更加通用和灵活的代码,可以在多种类型上进行操作而不需要重复编写逻辑。同时,TypeScript的类型检查器也能够在编译时检测出类型错误,提供更高的类型安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值