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();
相关推荐
Jayson柴9 分钟前
高德地图key
前端·javascript
vener_10 分钟前
ruoyi-python 若依python版本部署及新增模块
前端·javascript·vue.js·ruoyi
谢尔登34 分钟前
【Webpack】优化前端开发环境的热更新效率
前端·webpack·node.js
howard200538 分钟前
初试Bootstrap前端框架
前端·bootstrap
Mr.LiLong1 小时前
css 边框流光效果
前端·css
0wioiw01 小时前
Vue+Flask
前端·vue.js·flask
詹姆斯bind1 小时前
简单vue指令实现 el-table 可拖拽表格功能
前端·javascript·vue.js·elementui
凹凸曼打不赢小怪兽1 小时前
elementPlus的tree组件点击后有白色背景
前端·vue.js·elementui
low神2 小时前
React Native使用高德地图
javascript·react native·react.js
行深2 小时前
重构pdfjs阅读器viewer.html,实现双PDF对比(不依赖iframe、embed)
前端