function say3<T>(a: T): T {
return a + 1;
}
let speak = say3<number>(1)
我尝试了演示,但它说“类型‘number’不能分配给类型‘T’。”
T 不是数字吗?
这里的问题出在操作上+ 1
。 Typescript 无法确定您是否正在执行数字求和、字符串连接甚至是BigInt
手术。事实上,因为 T 类型的变量(其中 T 是任何可能的类型)加 1 的结果定义不明确,甚至可能返回与 T 不同的类型!我想到的一个特殊案例是[]+1=="1"
or {}+1==1
,情况下T
is an Array
and an Object
而该函数将返回一个string
or a number
分别。
当您对函数进行模板化时,无论可能的 T 类型如何,都需要明确定义该函数。换句话说,是的T
即使您稍后明确传递一个数字,也不是一个数字。
一个可能的修复方法是显式确定返回类型是数字并限制 T:
function say3<T extends number>(a: T): number {
return a + 1;
}
let speak = say3<number>(1)
或者,如果您确实希望 T 与其他类型一起使用,您可以进行运算符重载:
function say3(a: string): string
function say3(a: number): number
function say3(a: any[]): string
function say3(a: object): number
function say3(a: null): number
function say3(a: undefined): number
function say3(a: any) {
return a+1;
}
let speak = say3(1)
无论哪种方式,您都不能对未定义的类型调用运算符。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)