V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
love
V2EX  ›  TypeScript

为啥这个变量的类型和预期的不一样??

  •  
  •   love · 2019-10-18 21:19:16 +08:00 · 3096 次点击
    这是一个创建于 1642 天前的主题,其中的信息可能已经有所发展或是发生改变。
    const a: number[] = []
    const next: number | undefined = a[1]
    const x = next
    

    查看 Playground

    这里 x 的类型是 number,怎么不是 number | undefined ?

    我的意思是表示从数组中取一个值,它可能是 undefined,有什么标准写法?

    5 条回复    2020-02-08 10:00:15 +08:00
    rekey
        1
    rekey  
       2019-11-23 16:13:27 +08:00
    自动推导出 x 是 a[1]
    a 是 number[] 那 a[1] 是啥?
    weakish
        2
    weakish  
       2019-12-07 00:00:01 +08:00
    其实 next 你如果不注解的话,ts 自动推导的结果也是 `number`。所以你这里需要给 `x` 也加注解。

    之所以 ts 这里的类型直接推断为 number 是因为从数组中取一个值太常见了,给它开了后门,可以看 Anders Hejlsberg 本人的发言 aHR0cHM6Ly9naXRodWIuY29tL01pY3Jvc29mdC9UeXBlU2NyaXB0L3B1bGwvNzE0MCNpc3N1ZWNvbW1lbnQtMTkyNjcwNDUz (抱歉我不能直接贴 url,因为我的 V2EX 账号没绑手机,请自行转换一下)
    love
        3
    love  
    OP
       2019-12-07 21:42:33 +08:00
    @weakish 后来发现这个倒是不关数组的问题

    const next: number | undefined = 100
    这里 next 的类型实际上不是声明里指定的 number | undefined,而是 number
    和别的静态类型语言如 java 概念不一样,这个不太好理解上去。
    chnwillliu
        4
    chnwillliu  
       2020-02-08 00:02:10 +08:00 via Android
    @love 不是的呀,你没开 strictNullChecks,所以 null 和 undefined 是所有类型的子类型,也就是说变量 next 是 number 类型隐含了它可能为 undefined。
    love
        5
    love  
    OP
       2020-02-08 10:00:15 +08:00
    @chnwillliu
    开启时 next 也是 number 没有带 undefined

    const next: number | undefined = 100 as any
    const x: number = next
    const y: number | undefined = next
    这里 x 会报错。

    const next: number | undefined = 100
    const x: number = next
    const y: number | undefined = next
    这里不报错。

    这个类型声明没什么用,看的是右边是啥类型。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   976 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 30ms · UTC 20:21 · PVG 04:21 · LAX 13:21 · JFK 16:21
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.