react useState ts定义类型

在 React 中使用 useState 时,如果你在 TypeScript 里想为 useState 明确指定状态的类型,可以这样做:

1. 基础类型

比如,声明一个数字类型的 state:

tsx 复制代码
import React, { useState } from "react";

const Example: React.FC = () => {
  // 方式一:类型自动推断
  // const [count, setCount] = useState(0);

  // 方式二:显式指定类型
  const [count, setCount] = useState<number>(0);

  return (
    <div>
      <button onClick={() => setCount(count + 1)}>点击: {count}</button>
    </div>
  );
};

export default Example;

2. 对象类型

当 state 是对象时:

tsx 复制代码
type User = {
  name: string;
  age: number;
};

const [user, setUser] = useState<User>({ name: "张三", age: 18 });

3. 数组类型

tsx 复制代码
const [list, setList] = useState<string[]>([]);

4. 联合类型或可为空

如果 state 可能为 null,需要加上 null

tsx 复制代码
const [data, setData] = useState<string | null>(null);

总的语法形式:

tsx 复制代码
const [state, setState] = useState<类型>(初始值);

如果有具体的类型定义问题,可以把你的实际代码发出来帮你更详细解答!

相关推荐
m0_7482299919 小时前
Vue2 vs Vue3:核心差异全解析
前端·javascript·vue.js
2601_9495936519 小时前
高级进阶React Native 鸿蒙跨平台开发:LinearGradient 背景渐变与主题切换
react native·react.js·harmonyos
C澒19 小时前
前端监控系统的最佳实践
前端·安全·运维开发
xiaoxue..19 小时前
React 手写实现的 KeepAlive 组件
前端·javascript·react.js·面试
摘星编程20 小时前
在OpenHarmony上用React Native:自定义useHighlight关键词高亮
javascript·react native·react.js
hhy_smile20 小时前
Class in Python
java·前端·python
小邓吖20 小时前
自己做了一个工具网站
前端·分布式·后端·中间件·架构·golang
南风知我意95720 小时前
【前端面试2】基础面试(杂项)
前端·面试·职场和发展
LJianK121 小时前
BUG: Uncaught Error: [DecimalError] Invalid argument: .0
前端
No Silver Bullet21 小时前
Nginx 内存不足对Web 应用的影响分析
运维·前端·nginx