RT
用了 react-router-dom v4
从列表页( List )点击一项进入详情页( Detail ),在 Detail 里点击返回,返回到 List,这里 List 会重新加载,也就是说,之前在 List 里进行的加载更多也没有了,之前翻到的位置也没有了(直接到顶部了)
跳转用的是 Link
传统的服务器渲染的页面,点击一个超链接后,再返回,浏览器就算会刷新页面,但会回到之前的位置,用 react-router-dom 里的 Link 也是渲染成了超链接了呀,为啥返回就不能回到之前的位置呢?
对于这样的现象,可以在 List 页面加载完数据后就保存它的 state 到 redux/localStorage 里,从 Detail 返回到 List 页面的时候直接取就可以了,另外回到之前滚动的位置也可以在跳转前存一下滚动的位置 scrollTop,从 Detail 返回的时候,可以设置一下
问:目前除了上面这种方法外,还有其它的办法吗?求教!!
路由代码:
class App extends Component {
render() {
return (
<BrowserRouter>
<div>
<Route path="/" exact component={List}/>
<Route path="/topic/:id" render={({match})=>{
return <Detail id={match.params.id}/>
}}/>
</div>
</BrowserRouter>
);
}
}
跳转代码:
<Link to={`/topic/${v.id}`}>
<h4>{v.title}</h4>
</Link>
返回使用浏览器返回键和使用代码 this.props.history.goBack()
一样都可以返回,但 List 页面会重新加载
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.