[英]Typescript inference error - variable with type string changes to undefined inside for loop
我正在使用 await-to-js 库进行错误处理(下面示例中的to
方法来自该库)
由于某种原因,变量的类型更改为string | undefined
在for..of
循环内string | undefined
,当同一变量的值是循环外的string
时。
考虑以下示例(有关错误,请参见testMethod
):
function to<T, U = Error>(
promise: Promise<T>,
errorExt?: object
): Promise<[U, undefined] | [null, T]> {
return promise
.then<[null, T]>((data: T) => [null, data])
.catch<[U, undefined]>((err: U) => {
if (errorExt) {
const parsedError = Object.assign({}, err, errorExt);
return [parsedError, undefined];
}
return [err, undefined];
});
}
async function retrieveAccessToken(): Promise<string> {
const randomNumber = Math.random();
if(randomNumber < 0.5) {
throw new Error("Failed");
}
return "testToken";
}
function printAccessToken(accessToken: string) {
console.log(accessToken);
};
async function testMethod(): Promise<boolean> {
const accessTokenPromise = retrieveAccessToken();
const [err, accessToken] = await to(accessTokenPromise);
if(err){
console.log("Failed");
return false;
}
// No error here
printAccessToken(accessToken);
for(let i = 0 ; i < 5; i++){
// Error! Type Argument of type 'string | undefined' is not assignable to
// parameter of type 'string'.
printAccessToken(accessToken);
}
return true;
}
这似乎可以通过在 accessToken 上添加 if 检查来解决,例如if(!accessToken)
但是为什么accessToken
的类型是string | undefined
是没有意义的。 在 for 循环内部string | undefined
但在其外部是string
?
TypeScript 在分析解构语法中的类型时存在问题。 要获得预期的行为,请将 to 的解析值分配to
局部变量,并在检查err
后引用accessToken
。
改变:
const [err, accessToken] = await to(accessTokenPromise);
if(err){
console.log("Failed");
return false;
}
进入:
const toResult = await to(accessTokenPromise);
const [err] = toResult;
if(err){
console.log("Failed");
return false;
}
const [, accessToken] = toResult;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.