V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
tomoya92
V2EX  ›  问与答

react-router-dom 怎么让第二个页面返回到第一个页面使得第一个页面不重新加载

  •  
  •   tomoya92 · 2017-08-29 09:17:50 +08:00 · 5641 次点击
    这是一个创建于 2647 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    第 1 条附言  ·  2018-01-05 14:26:00 +08:00

    刚在网上又搜了一下这个问题,发现了这个库,我还没做测试 https://github.com/vifird/react-keeper

    7 条回复    2017-08-29 14:11:24 +08:00
    learnshare
        1
    learnshare  
       2017-08-29 09:41:50 +08:00
    两个路由指向同一个目标元素,然后目标元素内判断当前该显示 /隐藏什么
    tomoya92
        2
    tomoya92  
    OP
       2017-08-29 09:51:16 +08:00
    @learnshare #1 好办法,不过页面里的组件多了,那不是很难控制?
    learnshare
        3
    learnshare  
       2017-08-29 10:26:25 +08:00
    @liygheart 另一种就是前端缓存页面的数据,没有数据或不需要更新的时候直接取缓存,否则从 API 加载数据
    tomoya92
        4
    tomoya92  
    OP
       2017-08-29 10:33:52 +08:00
    @learnshare #3 缓存数据我用了 localStorage,就是在跳转到 Detail 之前把 List 的 state 存到 localStorage 里,在 Detail 返回到 List 的时候,直接取 localStorage 里的数据,但这样 List 还是会回到顶部,其实就是页面重新渲染了一遍
    otakustay
        5
    otakustay  
       2017-08-29 10:47:49 +08:00
    数据存 store 里回来不就不刷新了么,然后把 scroll position 做成一个组件对应的值也丢 store 里
    learnshare
        6
    learnshare  
       2017-08-29 10:58:12 +08:00
    @liygheart 把位置也记录下来

    但其实不建议这么做,不如从其他角度优化使用体验,比如数据分页
    jin5354
        7
    jin5354  
       2017-08-29 14:11:24 +08:00
    vue 里就是一句 keep-alive 的事
    react 里没有简单的方法,自己手动缓存数据重新渲染吧
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1081 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 22:32 · PVG 06:32 · LAX 14:32 · JFK 17:32
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.