react-router4怎么在路由变化时重新渲染同一个组件?

发布于 2022-09-06 11:02:24 字数 381 浏览 9 评论 0

刚开始我的地址是:http://192.168.1.74:3000/#/houseDetail/788052?ldbh=29430025
然后我点击下一条时:

history.push({
            pathname: '/houseDetail/' + nextFwbh,
            search: `ldbh=${nextLdbh}`
        })

地址会变成http://192.168.1.74:3000/#/houseDetail/788053?ldbh=29430025,但是因为是同一个组件,这时页面不会重新加载,只是路由变了,有没有什么方法能够是路由重新渲染当前的组件?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

走走停停 2022-09-13 11:02:24

可以在这个组件的componentWillReceiveProps方法中去判断,当url变化时,这个方法会被调用,通过props.match.params获取最新url参数,然后执行相关逻辑。

好听的两个字的网名 2022-09-13 11:02:24

可以用 history 中的 listen 方法监听 url 的变化,然后通过 state 的变化触发渲染。

this.unlisten = history.listen(location => {
  this.setState({ pathname: location.pathname });
});
北方。的韩爷 2022-09-13 11:02:24
export default function (props) {
  return (<组件 {...props} key={search参数} />)
}

重新封装一下组件,加入一个key

疯狂的代价 2022-09-13 11:02:24

你确定它没有进入更新阶段?

‖放下 2022-09-13 11:02:24

在路由跳转的地方加入KEY是一个办法。

<Route path='/sdspace/offline/:id/detail' exact component={SdSpace.Detail} key={new Date().getTime()} />
<Route path='/sdspace/offline/:id/edit' exact component={SdSpace.Detail} key={new Date().getTime()} />
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文