简体   繁体   English

打字稿推断错误 - 类型字符串的变量在 for 循环内更改为未定义

[英]Typescript inference error - variable with type string changes to undefined inside for loop

I'm using await-to-js library for error handling (the to method in the example below comes from the library)我正在使用 await-to-js 库进行错误处理(下面示例中的to方法来自该库)

For some reason, the type of a variable changes to string | undefined由于某种原因,变量的类型更改为string | undefined string | undefined inside of a for..of loop, when the value of the same variable is string outside of the loop.for..of循环内string | undefined ,当同一变量的值是循环外的string时。

Consider the following example (see testMethod for error):考虑以下示例(有关错误,请参见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;
}

This seems to be solved by adding a if check on accessToken eg if(!accessToken) however it doesn't make sense why the type of accessToken is string | undefined这似乎可以通过在 accessToken 上添加 if 检查来解决,例如if(!accessToken)但是为什么accessToken的类型是string | undefined是没有意义的。 string | undefined inside of the for loop but string outside of it?在 for 循环内部string | undefined但在其外部是string

Typescript playground 打字稿游乐场

TypeScript has issues analyzing types in destructuring syntax. TypeScript 在分析解构语法中的类型时存在问题。 To get the expected behavior, assign the resolved value of to to a local variable, and reference accessToken after checking err .要获得预期的行为,请将 to 的解析值分配to局部变量,并在检查err引用accessToken

Change:改变:

    const [err, accessToken] = await to(accessTokenPromise);

    if(err){
        console.log("Failed");
        return false;
    }

Into:进入:

    const toResult = await to(accessTokenPromise);

    const [err] = toResult;
    if(err){
        console.log("Failed");
        return false;
    }
    const [, accessToken] = toResult;

Playground link 游乐场链接

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM