React store Rematch

Rematch

typescript 复制代码
import { init, RematchDispatch, RematchRootState } from '@rematch/core';
import selectPlugin from '@rematch/select';
import persistPlugin from '@rematch/persist';
import sessionStorage from 'redux-persist/lib/storage/session';
import models from './models';

const persistConfig = {
    key: 'root',
    storage: sessionStorage,
    // 	保留缓存白名单
    whitelist: []
};
const store = init({
    models,
    plugins: [
        selectPlugin(),
        persistPlugin(persistConfig)
    ],
});
// store 初始化

export const { select } = store;

export default store;

store

typescript 复制代码
export default {
common: {
	state,
	reducers: {
		setData(state, payload) {
			retrun {..state, ...payload}
		}
	},
	effects: dispatch => ({
		init (payload) {
		}
	})
	// or rootState 
	effects: {
		init(payload, rootState) {}
	}
}

存取

typescript 复制代码
import { useDispatch, useSelector } from 'react-redux';
const dispatch = useDispatch();
const common = useSelector(state => state.common);

dispatch.common.init();
相关推荐
码途潇潇15 小时前
JavaScript有哪些数据类型?如何判断一个变量的数据类型?
前端·javascript
满天星辰15 小时前
Vue真的是单向数据流?
前端·vue.js
细心细心再细心15 小时前
Nice-modal-react的使用
前端
我的写法有点潮16 小时前
JS中对象是怎么运算的呢
前端·javascript·面试
悠哉摸鱼大王16 小时前
NV12 转 RGB 完整指南
前端·javascript
一壶纱16 小时前
UniApp + Pinia 数据持久化
前端·数据库·uni-app
双向3316 小时前
【RAG+LLM实战指南】如何用检索增强生成破解AI幻觉难题?
前端
海云前端116 小时前
前端人必懂的浏览器指纹:不止是技术,更是求职加分项
前端
青莲84316 小时前
Java内存模型(JMM)与JVM内存区域完整详解
android·前端·面试
parade岁月16 小时前
把 Git 提交变成“可执行规范”:Commit 规范体系与 Husky/Commitlint/Commitizen/Lint-staged 全链路介绍
前端·代码规范