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

保留 Redux 状态

WBOY
发布: 2024-08-21 08:09:04
转载
1164人浏览过

保留 redux 状态

persist redux 状态是什么意思?

react 应用程序中的一个常见挑战是在页面重新加载后或在用户会话之间重新水合 redux 状态。典型的解决方法是通过 api 调用重新获取数据并将其存储在 redux 状态中。但是,您现在可以使用称为 persisted redux state 的技术来重新水化 redux 状态,而无需额外的 api 调用。

redux-persist 包

这个包和典型的 redux 包 @reduxjs/toolkit 和 react-redux 可用于创建一个 redux 状态,该状态可以在浏览器中的页面重新加载或用户会话中持续存在。

先决条件

  • 您有一个正在运行的 react 应用程序。

装置

使用此命令安装所有必要的包以设置持久的 redux 状态。

npm i --save @reduxjs/toolkit react-redux redux-persist
登录后复制

设置持久 redux 状态

1.配置你的 redux store [store.js].

jQuery模态窗留言板
jQuery模态窗留言板

jQuery模态窗留言板

jQuery模态窗留言板 261
查看详情 jQuery模态窗留言板
import { combinereducers, configurestore } from "@reduxjs/toolkit";
import sampleslice from "./sampleslice";
import storagesession from "redux-persist/lib/storage/session"; // session storage
import { flush, pause, persist, persistreducer, persiststore, purge, register, rehydrate } from 'redux-persist';

const rootreducer = combinereducers({
     sample : sampleslice.reducer;
})
const persistconfig = {
     key:'root',
     storage: storagesession,
}
const persistedreducer = persistreducer(persistconfig, rootreducer)
const store = configurestore({
     reducer: persistedreducer,
     middleware: (getdefaultmiddleware) => 
               getdefaultmiddleware({
                   serializablecheck: {
                         ignoredactions: [flush, rehydrate, pause, persist, purge, register],
           },
     }) 
})
const persister = persiststore(store);
export default store
登录后复制

注意:如果您希望 redux 不仅在重新加载之间持续存在,而且在浏览器中的用户会话之间持续存在,请替换

import storagesession from "redux-persist/lib/storage/session"; // session storage
登录后复制


导入与

import storagesession from "redux-persist/lib/storage"; // local storage
登录后复制

2.包装你的根组件[index.js].

import React from 'react';
import ReactDOM from 'react-dom/client';
import './index.css';
import { BrowserRouter } from 'react-router-dom';
import store, { persistor } from './store';
import { Provider } from 'react-redux';
import { PersistGate } from 'redux-persist/integration/react';
import App from './App';

const root = ReactDOM.createRoot(document.getElementById('root') as HTMLElement);
root.render(<BrowserRouter>
    <Provider store={store}>
        <PersistGate loading={null} persistor={persistor}>
            <App />
        </PersistGate>
    </Provider>
</BrowserRouter>);
登录后复制

完成!你的持久 redux 状态已经准备好了。

以上就是保留 Redux 状态的详细内容,更多请关注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号