0

0

React-Admin 上下文更新导致路由历史警告的解决办法

花韻仙語

花韻仙語

发布时间:2025-11-16 11:16:16

|

698人浏览过

|

来源于php中文网

原创

react-admin 上下文更新导致路由历史警告的解决办法

当在 React-Admin 应用中使用 Context 来管理全局状态,并在更新 Context 数据时遇到 "Warning: You cannot change ``" 警告,通常是因为每次 Context 值更新都会导致 `` 组件重新渲染,进而创建新的路由历史对象。本文将介绍如何通过手动传递路由历史对象来解决此问题,避免不必要的警告。

React Router 依赖于历史对象来管理应用的路由。React-Admin 内部也使用了 React Router。默认情况下,如果开发者没有显式地传递历史对象给 组件,React-Admin 会自动创建一个。当 Context 发生变化,导致 组件重新渲染时,就会创建一个新的历史对象,从而触发 React Router 的警告。

解决方案:手动创建并传递历史对象

要解决这个问题,我们需要手动创建一个历史对象,并将其传递给 组件。这样,即使 Context 发生变化, 组件重新渲染,使用的仍然是同一个历史对象,从而避免警告。

  1. 安装 history 库 (如果尚未安装):

    npm install history
  2. 创建历史对象并传递给 组件:

    import { Admin, Resource } from 'react-admin';
    import { createBrowserHistory } from 'history';
    import Dashboard from './Dashboard'; // 假设你有一个 Dashboard 组件
    import authProvider from './authProvider'; // 假设你有一个 authProvider
    import dataProvider from './dataProvider'; // 假设你有一个 dataProvider
    import ShowFoo from './ShowFoo'; // 假设你有一个 ShowFoo 组件
    
    const history = createBrowserHistory();
    
    const App = () => {
      return (
        
          
        
      );
    };
    
    export default App;

    在上面的代码中,我们首先导入 createBrowserHistory 函数,然后创建一个历史对象 history。最后,我们将这个历史对象作为 history 属性传递给 组件。

    椒图AI
    椒图AI

    中文AI修图神器,一句话搞定复杂修图

    下载

代码解释:

  • createBrowserHistory(): 创建一个基于浏览器历史记录的 history 对象。
  • history={history}: 将创建的 history 对象传递给 React-Admin 的 组件。

示例:结合 Context 使用

以下是一个结合 Context 使用的完整示例,展示了如何避免路由历史警告。

import React, { createContext, useState, useContext } from 'react';
import { Admin, Resource } from 'react-admin';
import { createBrowserHistory } from 'history';
import { Link, Typography } from '@mui/material';

// 假设你有一个 Dashboard 组件
import authProvider from './authProvider'; // 假设你有一个 authProvider
import dataProvider from './dataProvider'; // 假设你有一个 dataProvider
import ShowFoo from './ShowFoo'; // 假设你有一个 ShowFoo 组件

const AppContext = createContext({
    appData: {},
    setAppData: () => {},
});

const history = createBrowserHistory();

export const MyMenuLink = ({ primaryText, to, leftIcon, sidebarIsOpen, onMenuClick, dense, foo }) => {
    const { appData, setAppData } = useContext(AppContext);

    const clickHandler = (e) => {
        const newAppData = {
            ...appData,
            foo: foo,
        };
        setAppData(newAppData);
    };

    return (
        
            {primaryText}
        
    );
};

const App = () => {
  const [appData, setAppData] = useState({
    foo: null,
  });

  const appContextValue = {
      appData,
      setAppData
  }

  return (
    
        
          
        
    
  );
};

export default App;

注意事项:

  • 确保在整个应用生命周期内,只创建一个历史对象,并将其传递给 组件。
  • 如果使用了其他的路由库,例如 BrowserRouter,确保与 React-Admin 的路由机制兼容。

总结:

通过手动创建并传递历史对象给 React-Admin 的 组件,可以有效地避免因 Context 更新导致的路由历史警告。 这种方法确保了即使在组件重新渲染的情况下,React Router 仍然使用相同的历史对象,从而保证了路由的正确性和稳定性。 记住,始终保持对 React Router 和 React-Admin 路由机制的理解,以便更好地解决潜在的问题。

相关文章

路由优化大师
路由优化大师

路由优化大师是一款及简单的路由器设置管理软件,其主要功能是一键设置优化路由、屏广告、防蹭网、路由器全面检测及高级设置等,有需要的小伙伴快来保存下载体验吧!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
Golang 分布式缓存与高可用架构
Golang 分布式缓存与高可用架构

本专题系统讲解 Golang 在分布式缓存与高可用系统中的应用,涵盖缓存设计原理、Redis/Etcd集成、数据一致性与过期策略、分布式锁、缓存穿透/雪崩/击穿解决方案,以及高可用架构设计。通过实战案例,帮助开发者掌握 如何使用 Go 构建稳定、高性能的分布式缓存系统,提升大型系统的响应速度与可靠性。

26

2026.01.09

java学习网站推荐汇总
java学习网站推荐汇总

本专题整合了java学习网站相关内容,阅读专题下面的文章了解更多详细内容。

38

2026.01.08

java学习网站汇总
java学习网站汇总

本专题整合了java学习网站相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.01.08

正则表达式 删除
正则表达式 删除

本专题整合了正则表达式删除教程大全,阅读专题下面的文章了解更多详细教程。

49

2026.01.08

java 元空间 永久代
java 元空间 永久代

本专题整合了java中元空间和永久代的区别,阅读专题下面的文章了解更多详细内容。

4

2026.01.08

java 永久代和元空间
java 永久代和元空间

本专题整合了java中元空间和永久代的区别,阅读专题下面的文章了解更多详细内容。

0

2026.01.08

java成品网站源码资源大全
java成品网站源码资源大全

本专题整合了java成品网站源码相关内容,阅读专题下面的文章了解更多详细内容。

20

2026.01.08

java过滤器教程大全
java过滤器教程大全

本专题整合了java过滤器相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.08

作业帮网页版入口地址大全
作业帮网页版入口地址大全

本专题整合了作业帮网页版地址整理,阅读专题下面的文章了解更多详细内容。

7

2026.01.08

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.4万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

React核心原理新老生命周期精讲
React核心原理新老生命周期精讲

共12课时 | 1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号