[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>>>>,
];

 

posted @   Zhentiw  阅读(7)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源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
点击右上角即可分享
微信分享提示