[Typescript] The Inference Mystery Solved
When we pass in "div"
to document.querySelector
, it returns an HTMLDivElement
or null
.
Similarly, when we pass it "span"
we're getting an HTMLSpanElement
.
So we're getting nice specific types when we pass in div
and when we pass in span
.
However, when we pass in "div.foo"
, we'll get back either element
or null
.
import { Equal, Expect } from "../helpers/type-utils";
const divElement = document.querySelector("div");
const spanElement = document.querySelector("span");
/**
* Your challenge: figure out why divElement2 is NOT
* of type HTMLDivElement.
*/
const divElement2 = document.querySelector("div.foo");
// ^? Element | null
type tests = [
Expect<Equal<typeof divElement, HTMLDivElement | null>>,
Expect<Equal<typeof spanElement, HTMLSpanElement | null>>,
Expect<Equal<typeof divElement2, HTMLDivElement | null>> // doesn't pass
];
Check how `querySelector` is defined:
querySelector<K extends keyof HTMLElementTagNameMap>(selectors: K): HTMLElementTagNameMap[K] | null;
querySelector<K extends keyof SVGElementTagNameMap>(selectors: K): SVGElementTagNameMap[K] | null;
querySelector<E extends Element = Element>(selectors: string): E | null;
Because it is using HTMLElementTagNameMap[K]
, but HTMLElementTagNameMap['div.foo']
cannot find a value.
So solution: const divElement2 = document.querySelector<HTMLDivElement>("div.foo");
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2022-02-02 [AWS] AWS Control Tower for multi accounts
2018-02-02 [Typescript] Build Method decorators in Typescript
2017-02-02 [Javascript] Write a function pipeline
2017-02-02 [React] Pass Data To Event Handlers with Partial Function Application
2016-02-02 [Cycle.js] Read effects from the DOM: click events
2016-02-02 [Cycle.js] Introducing run() and driver functions
2016-02-02 [Cycle.js] Customizing effects from the main function