TypeScript中,如何判断一个对象的字段是否为number类型

在TypeScript中,可以使用内联类型注解判断一个对象的字段是否为number类型,例如:

1
2
3
4
5
6
7
8
9
10
11
12
interface MyObject { 
  foo: number; 
  bar?: string; 
   
const myObj: MyObject = { foo: 123, bar: "baz" }; 
   
if (typeof myObj.foo === "number") { 
  console.log("myObj.foo is a number"); 
} else
  console.log("myObj.foo is not a number"); 
} // 输出 "myObj.foo is a number"

另外,也可以使用typeof运算符来判断一个对象的字段是否为number类型,例如:

1
2
3
4
5
if (typeof myObj.foo === "number") { 
  console.log("myObj.foo is a number"); 
} else
  console.log("myObj.foo is not a number"); 
} // 输出 "myObj.foo is a number"

需要注意的是,使用typeof运算符判断内联类型注解为"number"时,并不能检测出该字段的实际类型是否为number,而只是检测该字段是否为数字类型的值。如果该字段的实际类型不是number,但值是数字,那么typeof运算符也会返回"number"。

posted @   lanedm  阅读(676)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示