[Typescript] Index access types
Indexed Access types provide a mechanism for retrieving part(s) of an array or object type via indices. We’ll look at how this kind of type works, and a couple of practical examples of where you might use them.
interface Car {
make: string
model: string
year: number
color: {
red: string
green: string
blue: string
}
}
We can get color
type:
let carColor: Car["color"]
/*
let carColor: {
red: string;
green: string;
blue: string;
}
*/
We can get nested prop type:
let carColorRedComponent: Car["color"]["red"] // string
Index access type has safe guard:
let carColor: Car["not-something-on-car"] // ERROR: Property 'not-something-on-car' does not exist on type 'Car'.
We can get Intersection types on index access types:
let carPropertyWeInterest: Car["color" | "year", "model"]
/*
string | number | {
red: string;
green: string;
blue: string;
}
*/
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2021-08-16 [Unit testing] Simplify Assertions on Error Messages with toMatchInlineSnapshot
2021-08-16 [SAA + SAP] 27. Cost saving for data transfer out AWS
2020-08-16 [Linear Algebra] Inverse and Transpose
2020-08-16 [Linear Algebra] Matrix-Matrix Multiplication
2019-08-16 [GraphQL] Set variable and default value & alias
2018-08-16 [Debug] Node-sass
2018-08-16 [Java Sprint] AutoWire