umi-plugin-dvax
TypeScript icon, indicating that this package has built-in type declarations

1.1.0 • Public • Published

Plugin-dvax

umi 插件,dva 用法封装

Install

yarn add umi-plugin-dvax

Usage

启用插件,在.umirc.ts:

export default defineConfig({
  dva: {
    // 跳过model检测
    skipModelValidate: true,
  },
});

在 model 文件内:

import { createModel } from "@@/plugin-dvax";

interface Param {
  a: number;
}

export default createModel<Param>({
  namespace: "test-model",
  state: {
    a: 1,
  },
  // 自定义reducer
  reducer: {
    add: (state, action) => {
      return {
        ...state,
        a: state.a + 1,
      };
    },
  },
});

在组件内使用:

export default function Index() {
  // 响应式获取数据
  const { a } = useSelector(testModel.selector);

  // 非响应式获取数据
  const getState = () => {
    const { a } = testModel.getState();
    return a;
  };

  // 修改
  const update = () => {
    testModel.actions.update({ a: a + 1 });
  };

  // 重置
  const reset = () => {
    testModel.actions.reset();
  };

  // dispatch
  const add = () => {
    testModel.dispatch("add");
  };

  return <div>{a}</div>;
}

Readme

Keywords

Package Sidebar

Install

npm i umi-plugin-dvax

Weekly Downloads

1

Version

1.1.0

License

MIT

Unpacked Size

4.69 kB

Total Files

6

Last publish

Collaborators

  • zhengjiahao