- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我尝试运行我的应用程序时,开发者工具给我这个错误。
我想不通,因为我将 Switch 组件放在了 ConnectedRouter 中。有什么想法吗?
src.ca056580.js:28856 Uncaught Error: You should not use <Switch> outside a <Router>
src.ca056580.js:25432 The above error occurred in one of your React components:
in Switch (created by Routes)
in Routes (created by AuthenticatedAppView)
in ErrorBoundary (created by AuthenticatedAppView)
in div (created by Tag(div))
in Tag(div) (created by AppWidth)
in AppWidth (created by AppContent)
in main (created by index_AppContentLayout)
in index_AppContentLayout (created by AppContent)
in AppContent (created by AuthenticatedAppView)
in div (created by Tag(div))
in Tag(div) (created by index_AppLayout)
in index_AppLayout (created by AuthenticatedAppView)
in AuthenticatedAppView (created by Connect(AuthenticatedAppView))
in Connect(AuthenticatedAppView) (created by Route)
in Route (created by withRouter(Connect(AuthenticatedAppView)))
in withRouter(Connect(AuthenticatedAppView)) (created by App)
in Router (created by ConnectedRouter)
in ConnectedRouter (created by App)
in Provider (created by App)
in App (created by HotExportedApp)
in AppContainer (created by HotExportedApp)
in HotExportedApp
in ModalStack (created by AppRoot)
in OverlayState (created by AppRoot)
in div (created by AppLayerContainer)
in AppLayerContainer (created by AppLayers)
in div (created by AppLayerContainer)
in AppLayerContainer (created by AppLayers)
in AppLayers (created by AppRoot)
in AppRoot
但是您可以看到 ConnectRouter 已经创建。以下是代码片段。
AuthenticatedApp 导入了一个 Routes 组件,其中包含
class AuthenticatedAppView extends Component<AuthenticatedAppViewProps> {
componentDidMount() {
this.props.fetchCompanies()
}
render() {
return (
<AppLayout>
<MenuBar />
<AppContent>
<ErrorBoundary
errorTitle="We're having trouble loading the requested page."
errorComponent={ErrorView}
>
<Routes />
</ErrorBoundary>
</AppContent>
</AppLayout>
)
}
}
这是Routes组件,包含Switch和路由
const Routes = () => (
<Switch>
<Route path="/" exact render={() => <Redirect to="/companies" />} />
<Route path="/companies" component={SelectCompanies} />
<Route render={() => <RouteNotDefined />} />
</Switch>
)
export default Routes
这是App/组件,它在Router中包含了AuthenticatedApp组件,所以Switch应该也在Router中。我做错了什么?
import React from 'react'
import { hot } from 'react-hot-loader'
import { Provider } from 'react-redux'
import { ConnectedRouter as Router } from 'react-router-redux'
import createHistory from 'history/createBrowserHistory'
import { configureStore } from './configureStore'
import AuthenticatedApp from './AuthenticatedApp'
const history = createHistory({ basename: '/' })
const store = configureStore(history)
const App = () => (
<Provider store={store}>
<Router history={history}>
<AuthenticatedApp />
</Router>
</Provider>
)
export default hot(module)(App)
最佳答案
React Router Redux 已被弃用,因此您的错误很可能是此弃用的结果。您应该迁移到 React Router,它可以很好地与 Redux 配合使用(请参阅 router-side、redux-side)。
您需要 npm install react-router-dom
以便在浏览器中使用。
借助 React Router,您可以使用 BrowserRouter替换您的 ConnectedRouter。
这是一个示例(在 App.js 中):
import React from 'react';
import { Provider } from 'react-redux';
import { BrowserRouter } from 'react-router-dom';
import { store } from './redux-store';
import AuthenticatedApp from './AuthenticatedApp'
const App = () => {
<Provider store={ store }>
<BrowserRouter>
<App />
</BrowserRouter>
</Provider>
}
关于javascript - 未捕获错误 : You should not use <Switch> outside a <Router>, 但开关在里面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52940120/
我有一个已发布的库,其中包含一个在其模板中使用 [routerLink] 的组件。在我的应用程序中安装库后,我收到错误 NullInjectorError:R3InjectorError(AppMod
/~/@ReMix-Run/Router/dist/router.cjs.js模块分析失败:/HOME/sharib/Desktop/Full Stack Developer Tutorial/MER
在 vuejs 2 中,我能够通过返回渲染 html 标签直接在路由器中渲染。我正在尝试使用 vue-router 4 在 vue3 中做同样的事情,但它似乎不起作用: { path:
在我的应用程序中,我使用 vue-router。当我使用 router.map({}) 将路由传递给路由器时,路由可以工作,但当我在构造函数中传递它们时,路由就不起作用。知道这是为什么吗? // wo
我正在 react 应用程序中实现路由。我对react-router 4.0相对于react-router-redux的优势感到困惑。我也对react-router-dom感到困惑。 react-ro
我有以下两条路线:/items和/items/buy。 每个路线在一个 View 中对应一个选项卡。两条路线均使用精确的 Prop 进行渲染,但导航至/items/buy时,仍将两个选项卡标记为事件选
我有一个带有 url/product/0 的新产品页面。当使用按钮保存产品时,我想显示“已成功保存”消息并将 url 更改为/product/1024 而无需实际导航到该页面,因为这会导致对页面上的产
我对此有些困惑。我定义了一条名为classes/:id的路线。在应用程序中导航到该路线时,将调用componentDidMount()。但是,当重新加载页面或复制并粘贴URL时,页面将完全加载,但根本
假设我有以下2条路线: ... ... 现在,当我尝试按路线/news时,会触发带有Home参数的param1的根路线... 我认为解决方案是在像/?param1这
我正在将 Vue Router 与 Vue 3 一起使用,并尝试添加一个包罗万象的路由以在用户尝试访问无效 URL 时重定向用户。当我尝试使用通配符 (*) 时,我将以下错误记录到控制台: Uncau
我在我的项目中使用react-router-dom 4.0.0-beta.6。我有如下代码: 我想在 HomePage 组件中获取查询参数。我找到了 location.search 参数,它看起来像
我正在使用 Vue 路由器。在我的代码中,我曾经有: 这有效,并且页面数据被传递到组件。但是如何使用路由器 View 执行相同的操作呢?这似乎不起作用: js: var vm = new Vue(
我目前正在一个项目中使用react-router-redux,除了我不知道如何访问react-router路由器之外,一切都工作正常。 @connect((state, props) => {
当使用链接时,路由器按预期工作,尽管我收到警告 [history] pushState is deprecated;使用推送代替。 使用react-router-redux中的routeActio
我想创建一个多页 Meteor 网络和移动应用程序。因此,我正在寻找路由服务。 来自 research ,我收集了Iron Router就是我要找的。但是很多教程也提到了Meteor.Router I
我正在使用 React Router(版本 4.0.0)和 Router组件有一个名为“history”的必需 Prop 。 我知道在以前版本的react-router中你可以导入browserHis
我正在使用 氟罗包用于导航。 Fluro 和 Flutter 正在使用“路由器”。所以他们的类(class)合并了。我怎么能解决这个问题? lib/routers/routers.dart:2:1:
自从我更新了 Vue.js 应用程序的节点包后,我在浏览器控制台中收到以下警告: [vue-router] 's tag prop is deprecated and has beenremoved
我正在尝试在我的应用程序中将 react-router 更新到 v2.6 并将 react-router-relay 更新到 v0.7,但我正在努力按照变更日志来解决所有重大变更。我想我解决了所有的变
router-view 和 router-link 组件无法在我的应用中解析不知道是什么问题 附上应用代码它是一个主页应用程序,带有类似 navbar 的东西,用于路由到 vue 组件,如 state
我是一名优秀的程序员,十分优秀!