찾다

 >  Q&A  >  본문

javascript - react-router侦听url变化的原理?

用react-router不多,想问一下实现原理。
我在地址栏里修改了url,然后回车,组件进入了componentWillReceiveProps这个生命周期,也就是更新组件;
再次回车时,就变成重新加载,组件从componentWillMount开始新的生命周期。

是不是react-router侦听了hashchange,如果url变化则手动pushState然后触发React组件重新渲染,如果url不变的话则重新请求这个页面?有没有对react-router实现原理比较了解的大神解释一下。

使用的是react-router 2.8

巴扎黑巴扎黑2776일 전383

모든 응답(2)나는 대답할 것이다

  • 高洛峰

    高洛峰2017-04-11 12:55:29

    在地址栏里敲回车页面刷新的时候其实跟 React 没关系了,componentWillMount 也不会被执行。另外 react-router 是通过 history 这个包来跟 URL 做同步的。

    회신하다
    0
  • 高洛峰

    高洛峰2017-04-11 12:55:29

    其实可以在链接中加上onClick改变state从而达到url变化组件重新渲染的,但是我也遇到问题了。。。

    회신하다
    0
  • 취소회신하다