data:image/s3,"s3://crabby-images/595b9/595b93960a85cc667ce8fd08d02bc93846d53027" alt="深入理解React Router:从原理到实践"
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人
2.2.3 history监听
browserHistory的browserHistory.listen方法监听browserHistory的location的改变,通过hisotry.push、history.replace、history.go等方法改变location,都会触发回调监听函数。各方法除了能获得最新导航的location地址,还能获取到不同的跳转类型action。其调用方式如下:
data:image/s3,"s3://crabby-images/c34c8/c34c8633eb4417887e9eba98fe1fdd80a0659876" alt=""
history.listen的回调函数仅在产生导航、location发生变化时被触发,页面初始加载不会被触发。在页面初始加载后,页面地址会同步到history.location中。注意,这里监听location“变化”并不表示前后导航过程中location的值不一致发生变化,当前后导航过程中产生的location一致时,同样会触发history.listen的回调函数。
如果希望在history.listen的回调函数中获取上一次浏览记录,则可通过声明外部变量实现:
data:image/s3,"s3://crabby-images/e46d0/e46d0f78f48f91a04654be699d733b709347a573" alt=""
data:image/s3,"s3://crabby-images/31d7c/31d7c84fb1f23919f3d3c2a22bb60d5cfbf55033" alt=""