react-router4怎么在路由变化时重新渲染同一个组件?
刚开始我的地址是: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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(5)
可以在这个组件的componentWillReceiveProps方法中去判断,当url变化时,这个方法会被调用,通过props.match.params获取最新url参数,然后执行相关逻辑。
可以用 history 中的 listen 方法监听 url 的变化,然后通过 state 的变化触发渲染。
重新封装一下组件,加入一个key
你确定它没有进入更新阶段?
在路由跳转的地方加入KEY是一个办法。