当前位置: 首页 > news >正文

react如何使用useContext + TS 自定义hooks

为了在 TypeScript 中为 useContext 提供良好的类型提示,我们需要为 Context 定义类型,并确保在创建和使用 Context 时应用这些类型。这可以帮助我们获得更好的类型检查和智能提示。

示例:在用户认证示例中添加 TypeScript 类型

  1. 定义类型

首先,定义与 Context 相关的数据结构和类型。


// 定义用户和认证状态的类型
interface User {username: string;
}interface AuthContextType {user: User | null;login: (username: string) => void;logout: () => void;
}
  1. 创建 Context 并提供值

在创建和使用 Context 时应用这些类型。


import React, { createContext, useContext, useState, ReactNode } from 'react';// 创建 Context,初始值为 undefined
const AuthContext = createContext<AuthContextType | undefined>(undefined);interface AuthProviderProps {children: ReactNode;
}export function AuthProvider({ children }: AuthProviderProps) {const [user, setUser] = useState<User | null>(null);const login = (username: string) => {setUser({ username });};const logout = () => {setUser(null);};// 提供的值包含用户状态和登录、登出函数const value = {user,login,logout,};return (<AuthContext.Provider value={value}>{children}</AuthContext.Provider>);
}export function useAuth() {const context = useContext(AuthContext);if (context === undefined) {throw new Error('useAuth must be used within an AuthProvider');}return context;
}
  1. 在组件中使用 Context

当我们在组件中使用 useAuth 时,TypeScript 将提供准确的类型提示。


import React from 'react';
import { useAuth, AuthProvider } from './AuthContext';function UserProfile() {const { user, logout } = useAuth();return (<div>{user ? (<><p>Welcome, {user.username}!</p><button onClick={logout}>Logout</button></>) : (<p>Please log in.</p>)}</div>);
}function LoginForm() {const { login } = useAuth();const handleLogin = () => {login('username');};return (<button onClick={handleLogin}>Login</button>);
}function App() {return (<AuthProvider><UserProfile /><LoginForm /></AuthProvider>);
}export default App;

总结

通过在 Context 和相关函数中添加类型定义,我们可以在 TypeScript 中获得更好的类型检查和智能提示。这些类型定义有助于捕获潜在的错误,并使代码更易于维护和理解。

http://www.lryc.cn/news/419047.html

相关文章:

  • 【网络安全学习】SQL注入03:如何防止SQL注入
  • linux利用crontab捕获iotop
  • android13 关闭selinux 临时关闭或者永久关闭
  • JetBrains GoLand单元测试不支持单个单元测试case执行
  • 基于STM32设计的盆栽种植自动管理系统(微信小程序)(201)
  • 白骑士的PyCharm教学实战项目篇 4.1 Web应用开发
  • Linux与Docker常用运维命令一览
  • 怎样在 SQL 中创建视图(VIEW),以及视图的作用和优势是什么?
  • Tomcat 使用和配置文件(详解)
  • html+css+js+jquery实现一个 飘零的树叶
  • 鸿蒙(API 12 Beta3版)【时域可分层视频编码】 音视频编码
  • 一个java类实现UDP代理转发
  • K8s问题案例分析
  • 爬虫集群部署:Gerapy 框架详细解析
  • 文本相似度 HanPL汉语言处理
  • Linux软件包管理器 yum
  • 图像变换算法
  • 谷粒商城实战笔记-131~132-商城业务-商品上架-构造sku检索属性和库存查询
  • 【Python学习-UI界面】PyQt5 QLabel小部件
  • vue项目打包问题
  • C++标准模板库(STL)|容器|vector| queue|
  • 【Android】安卓四大组件之Service用法
  • Python爬虫入门实战(详细步骤)
  • 5、Linux : 网络相关
  • Linux中针对文件权限的解析
  • 【0304】psql 执行“VACUUM FULL”命令的背后实现过程
  • Java常见面试题-11-MongoDb
  • PBLOCK
  • 电子纸打造智能、自动化、绿色的工作流程
  • Redis 的6种回收策略(淘汰策略)详解