为啥 typescript 这行会报错?

2020-07-13 15:23:52 +08:00
 love

https://www.typescriptlang.org/play/index.html#code/KYDwDg9gTgLgBASwHY2FAZgQwMbDgeTBgQiQGc4BvAKDjrjJigH4AuBp5Ac2oF9rq6AK5JsxUnHQAKCETLtC48gEoqtegnRwpAQlkwyAOkZRVMABZQIAdzhJgtgKJQrUKcvV1spRg3YnuOABeOH0jE084b3J4EGC4AG0AckwkgF1DAFtMMCkAE2CAPjgCgGpQuWMmD3oon3gAT3jk1Izs3IKg4rzjMAAbBBgZSpNlVQB6cbg0Vz5qIA

export interface Options {
    str?: string
}

function f(opts: Options) {
    if (!opts.str) throw new Error()
    const s: string = opts.str
    const x = ['a'].map(d => d + opts.str)
    const y = ['a'].map(d => d.split(opts.str)) // error: opts.str: Type 'undefined' is not assignable to type 'string | RegExp'.
}
2055 次点击
所在节点    TypeScript
3 条回复
RRRSSS
2020-10-13 15:36:15 +08:00
因为 ts 不知道 opts.str 是 string 还是 undefined
love
2020-10-13 16:03:07 +08:00
@RRRSSS
function f(opts: Options) {
if (!opts.str) throw new Error() # A
const s = opts.str
const x = ['a'].map(d => d + opts.str)
const y = ['a'].map(d => d.split(opts.str)) // error
}

可是行 A 不是已经排除掉 undefined 的可能了吗?
下面的变量 s 的类型被自动推断为 string 而不是 string|undefined,看来原因就是 ts 子函数里所有的上层的类型断言会失效。
TanMusong
2020-10-14 20:18:27 +08:00
=>
专业名词忘了,反正已经算另一个域了,判断只在这个方法里起作用

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/689597

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX