- 当我测试自定义钩子组件时,我使用从@testing-library/react'导入的renderhook和从react-dom/test-utils'导入的act。
・src/app.tsx
import "./app.css"; import counter from "./component/counter/counter"; function app() { return ( <p classname="app"> <counter></counter> </p> ); } export default app;
登录后复制
・src/component/counter/counter.tsx
import react, { usestate } from "react"; import { usecounter } from "../../hooks/usecounter"; const counter = () => { const { count, increment } = usecounter({ initialcount: 10 }); return ( <p> <h1>{count}</h1> <button onclick="{()"> increment()}>increment</button> </p> ); }; export default counter;
登录后复制
・src/hooks/usecounter.tsx
import react, { usestate } from "react"; import { usecounterprops } from "./usecounter.type"; type usecounterprops = { initialcount?: number; }; export const usecounter = ({ initialcount = 0 }: usecounterprops = {}) => { const [count, setcount] = usestate(initialcount); const increment = () => setcount((prev) => prev + 1); return { count, increment }; };
登录后复制
・src/hooks/usecounter.test.tsx
import { renderHook } from "@testing-library/react"; import { useCounter } from "./useCounter"; import { act } from "react-dom/test-utils"; describe("useCounter", () => { test("Should render the initial count", () => { const { result } = renderHook(useCounter, { initialProps: { initialCount: 10 }, }); expect(result.current.count).toBe(10); }); test("Increment the count", () => { const { result } = renderHook(useCounter); act(() => { result.current.increment(); }); expect(result.current.count).toBe(1); }); });
登录后复制
当我传递一个props时,在本例中它是initialcount(= 10),我添加了一个属性initialprops:{initialcount:10}。
当我测试自定义钩子的函数(在本例中为increment())时,我使用该行为并在回调中调用increment()。
・成功
・失败
・显示动作
以上就是React 基础知识~单元测试/自定义钩子的详细内容,更多请关注抖狐科技其它相关文章!
-
天猫精灵怎么恢复出厂设置 恢复出厂设置操作方法
天猫精灵出现故障?别着急!php小编子墨为您提供了一份详尽的指南,带您轻松恢复出厂设置,解决设备问题。本指南将逐步指导您整个恢复过程,并提供故障排除建议。如果您遇到持续的问题,请联系专业技术支持人员寻...
-
美联储降息50基点引爆加密市场 持续降息将迎来牛市
经过四年的等待,美国联邦储备系统在昨日的晨间会议中宣布了首次降息,幅度为50个基点。这一决策的公布,或将为长期低迷的加密货币市场注入了新的活力。根据Binance数据,比特币从 5.8万美元最高冲至...
-
系统重装后怎么添加图标
系统重装后添加桌面图标的方式:安装桌面环境:安装 gnome、kde 或 xfce 等桌面环境。添加应用程序:从启动器右键单击应用程序并选择 "添加到启动器"。创建自定义图标:创建 128x128 像...
-
怎么让Windows 11看起来像Windows 10
让 win11 尽显 win10 风采当 windows 11 的新颖外观不再让你心动,你是不是怀念起了经典的 win10 风格?不要担心,php小编香蕉将为你提供详细的操作指南,让你轻松地将自己的...
-
《永恒空间2》首个大型DLC泰坦上线 大量新内容
9月17日今天,好评太空冒险游戏《永恒空间2 》首个大型DLC·泰坦上线,追加新的故事、物品套装、传奇装备、催化剂、消耗品等大量新内容,敬请期待。《永恒空间2》是一款快节奏的单人太空射击游戏,拥有太空...