使用 Immer 的 React Hook:use-immer 项目教程

使用 Immer 的 React Hook:use-immer 项目教程

use-immerUse immer to drive state with a React hooks项目地址:https://gitcode.com/gh_mirrors/us/use-immer

1. 项目的目录结构及介绍

use-immer/
├── src/
│   ├── index.js
│   ├── use-immer.js
│   └── example/
│       ├── Form.js
│       ├── TodoList.js
│       └── App.js
├── .gitignore
├── CHANGELOG.md
├── LICENSE
├── README.md
├── package.json
├── tsconfig.json
└── yarn.lock

目录结构介绍

  • src/: 包含项目的源代码文件。
    • index.js: 项目的入口文件。
    • use-immer.js: 实现 useImmeruseImmerReducer 的核心文件。
    • example/: 包含示例代码。
      • Form.js: 使用 useImmer 的表单示例。
      • TodoList.js: 使用 useImmer 的待办事项列表示例。
      • App.js: 示例应用的主组件。
  • .gitignore: Git 忽略文件配置。
  • CHANGELOG.md: 项目更新日志。
  • LICENSE: 项目许可证。
  • README.md: 项目说明文档。
  • package.json: 项目依赖和脚本配置。
  • tsconfig.json: TypeScript 配置文件。
  • yarn.lock: Yarn 包管理器生成的锁定文件。

2. 项目的启动文件介绍

index.js

index.js 是项目的入口文件,负责导出 useImmeruseImmerReducer 钩子函数。

export { useImmer } from "./use-immer";
export { useImmerReducer } from "./use-immer";

use-immer.js

use-immer.js 文件实现了 useImmeruseImmerReducer 钩子函数,允许在 React 中使用 Immer 来管理状态。

import { useReducer } from "react";
import produce from "immer";

export function useImmer(initialValue) {
  const [state, updateState] = useReducer(
    (draft, newState) => (typeof newState === "function" ? newState(draft) : newState),
    initialValue
  );
  return [state, updateState];
}

export function useImmerReducer(reducer, initialState, initialAction) {
  return useReducer(
    (state, action) => produce(state, draft => reducer(draft, action)),
    initialState,
    initialAction
  );
}

3. 项目的配置文件介绍

package.json

package.json 文件包含了项目的依赖、脚本和其他元数据。

{
  "name": "use-immer",
  "version": "0.6.0",
  "description": "Use immer to drive state with a React hooks",
  "main": "src/index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "repository": {
    "type": "git",
    "url": "git+https://github.com/immerjs/use-immer.git"
  },
  "keywords": [
    "immer",
    "react",
    "hooks"
  ],
  "author": "Michel Weststrate",
  "license": "MIT",
  "bugs": {
    "url": "https://github.com/immerjs/use-immer/issues"
  },
  "homepage": "https://github.com/immerjs/use-immer#readme",
  "peerDependencies": {
    "immer": "^7.0.0 || ^8.0.0 || ^9.0.0",
    "react": "^16.8.0 || ^17.0.0 || ^18.0.0"
  }
}

tsconfig.json

tsconfig.json 文件是 TypeScript 的配置文件,用于编译 TypeScript 代码。

{
  "compilerOptions": {
    "target":

use-immerUse immer to drive state with a React hooks项目地址:https://gitcode.com/gh_mirrors/us/use-immer

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

明树来

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值