react-router-dom怎么让第二个页面返回到第一个页面使得第一个页面不重新加载
发布于 7 年前 作者 tomoya92 16782 次浏览 来自 问答

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页面会重新加载

6 回复
  1. Detail 浮动显示 (fixed)
  2. 用 redux 记录 list 的 data 与 滚动条位置

把react-router(v4)换成了react-router(v2),再配合上react-router-scroll就可以完美的解决了

回到顶部