如何使用 React 路由器设置带有可选查询参数的路由?

IT技术 reactjs react-router query-parameters
2021-04-30 19:30:17

我有一条路径

 <Route path="/account/:accountid/LoginPage"
      component={LoginPage}/>

如果 url 是 -> ,这可以正常工作/account/12332/LoginPage我想要可选的查询参数。网址结构将是这样的

/account/12322/LoginPage?User=A&User=B

我已将路径修改为

<Route path="/account/:accountid/LoginPage(/:User)"
      component={LoginPage}/>

在此之后,如果我尝试访问该 url,它不会将我重定向到相应的页面,而是会引发错误

useBasename.js:56 Uncaught TypeError: history.getCurrentLocation is not a function
    at Object.getCurrentLocation (useBasename.js:56)
    at Object.getCurrentLocation (useQueries.js:64)
    at Object.listen (createTransitionManager.js:246)
    at Object.componentWillMount (Router.js:97)
    at ReactCompositeComponent.js:347
    at measureLifeCyclePerf (ReactCompositeComponent.js:75)
    at ReactCompositeComponentWrapper.performInitialMount (ReactCompositeComponent.js:346)
    at ReactCompositeComponentWrapper.mountComponent (ReactCompositeComponent.js:257)
    at Object.mountComponent (ReactReconciler.js:45)
    at ReactCompositeComponentWrapper.performInitialMount (ReactCompositeComponent.js:370)
1个回答

从 react-router v4(最新版本)开始,它不支持查询参数(?user=nerve&name=no-one)。不过它确实支持 URL 参数。有一个GitHub 问题讨论了同一点。继续阅读它,有一些很好的解决方案,但没有直接融入核心库。

我通常实施的一种解决方法是添加多个呈现相同组件的路由。

<Route exact path='/' component={ HomePageConnector } />
<Route exact path='/search/:searchTerm' component={ HomePageConnector } />

编辑

据我了解,v4 的唯一问题是它不再公开location.query对象。但是,您仍然可以访问location.search(这是一个字符串,而不是一个对象)。您可以读取此字符串并将其传递给查询字符串之类的库,以从中获取更有意义的对象。这样,您可以继续使用查询参数而不是 URL 参数。此信息已写在 GitHub 问题中,但在评论中有点分散。像(虽然没有测试):

路线:

<Route exact path='/test' component={HomePageConnector} />

获取组件中的参数:

const parseQueryString = require('query-string');

let queryString = this.props.location.search;
let queryParams = parseQueryString.parse(queryString);