React-Router路由跳转时render触发两次的情况
问题:React-Router路由跳转时,render触发两次,导致页面重复渲染。 原因:项目中使用的react-router ^3.x.x。react-router路由跳转时,this.props.location.action的值会有两种状态。这两种状态都会触发render。故页面渲染两次。 1. 当点击Link时,this.props.location.action=PUSH; 所以当点击了Link时,状态先是PUSH,之后浏览器发生前进后退,状态变为POP。
本人选择的是POP,因为项目中有些需求要使用到 window.location.hash='xxxxxxxx',这种情况PUSH是触发不到的,所以路由跳转会失败。 shouldComponentUpdate() { // POP 浏览器前进后退, PUSH 点击Link return this.props.location.action === "POP" } 备注:facebook官方说此情况是 react-router 的BUG,已经在 ^4.x.x中修复了。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |