首页 > web前端 > js教程 > 正文

React 基础知识~单元测试/自定义钩子

心靈之曲
发布: 2024-10-27 16:27:09
转载
461人浏览过
  • 当我测试自定义钩子组件时,我使用从@testing-library/react'导入的renderhook和从react-dom/test-utils'导入的act。

・src/app.tsx

import "./app.css";
import counter from "./component/counter/counter";

function app() {
  return (
    <div classname="app">
      <counter />
    </div>
  );
}

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 (
    <div>
      <h1>{count}</h1>
      <button onclick={() => increment()}>increment</button>
    </div>
  );
};

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()。

    硅基智能
    硅基智能

    基于Web3.0的元宇宙,去中心化的互联网,高质量、沉浸式元宇宙直播平台,用数字化重新定义直播

    硅基智能 62
    查看详情 硅基智能

・成功
React 基础知识~单元测试/自定义钩子

・失败
React 基础知识~单元测试/自定义钩子

・显示动作
React 基础知识~单元测试/自定义钩子

以上就是React 基础知识~单元测试/自定义钩子的详细内容,更多请关注php中文网其它相关文章!

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:dev.to网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号