[React Typescript] Fixing type inference in a Custom React Hook
// Problem
import { useState } from "react";
import { Equal, Expect } from "../helpers/type-utils";
export const useId = (defaultId: string) => {
const [id, setId] = useState(defaultId);
return [id, setId];
};
const [id, setId] = useId("1");
type tests = [
Expect<Equal<typeof id, string>>,
Expect<Equal<typeof setId, React.Dispatch<React.SetStateAction<string>>>>
];
the return type is actually:
(string | React.Dispatch<React.SetStateAction<string>> | undefined)[]
Two way to solve the problem:
1. Force the return type for the hook: not great, but working
import { useState } from "react";
import { Equal, Expect } from "../helpers/type-utils";
export const useId = (
defaultId: string,
): [string, React.Dispatch<React.SetStateAction<string>>] => {
const [id, setId] = useState(defaultId);
return [id, setId];
};
const [id, setId] = useId("1");
type tests = [
Expect<Equal<typeof id, string>>,
Expect<Equal<typeof setId, React.Dispatch<React.SetStateAction<string>>>>,
];
2. using as const
import { useState } from "react";
import { Equal, Expect } from "../helpers/type-utils";
export const useId = (defaultId: string) => {
const [id, setId] = useState(defaultId);
return [id, setId] as const;
};
const [id, setId] = useId("1");
type tests = [
Expect<Equal<typeof id, string>>,
Expect<Equal<typeof setId, React.Dispatch<React.SetStateAction<string>>>>,
];
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2022-08-16 [Typescript] Index access types
2022-08-16 [Typescript] Making TypeScript Stick - 6 - infer, build a ConstructorArg Type
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