data:image/s3,"s3://crabby-images/595b9/595b93960a85cc667ce8fd08d02bc93846d53027" alt="深入理解React Router:从原理到实践"
2.4.2 history导航
1.history.push
与browserHistory一样,其签名为:
data:image/s3,"s3://crabby-images/1fada/1fada4318856f4a28451a51a1ab126c749c5cd05" alt=""
对于memoryHistory,其location存储在内存中,在调用history.push后,得到的location既可通过memoryHistory.location获取,也可通过访问历史栈获取:
data:image/s3,"s3://crabby-images/8c61a/8c61a30d755d128ae23d5c50e7ea9258599cdd31" alt=""
与browserHistory、hashHistory一样,memoryHistory不仅支持调用block阻止跳转,还支持相对路径导航、保存state等:
data:image/s3,"s3://crabby-images/0bf2a/0bf2aa9045f7791cb984a681f55beba972836c28" alt=""
data:image/s3,"s3://crabby-images/16f62/16f62718769a18d6748fcc2f99411d508ec5d442" alt=""
注意,在memoryHistory导航过程中,所有信息都将保存到location中,不像browserHistory的key与state一样存在于window.history.state中进行持久化存储,memoryHistory导航过程中所有的key与state均存储在自身维护的内存中。
data:image/s3,"s3://crabby-images/018d5/018d5587820a240c9b78084c6afe7eddb5c58605" alt=""
对于history.push的实现,其模拟了浏览器管理历史记录的方法:
data:image/s3,"s3://crabby-images/0dc2e/0dc2ede4015a4893416e019123958dd63272834b" alt=""
2.history.replace
history.replace可替换历史栈内容,与browserHistory、hashHistory等均一致,其签名如下:
data:image/s3,"s3://crabby-images/35fa0/35fa09b74584f80c6b28caf2dd1a435f0884c7c2" alt=""
history.replace不增加栈记录:
data:image/s3,"s3://crabby-images/1a67a/1a67ab6b1d12b35dfb1eb92826d00d9ca4e39757" alt=""
对于history.replace,其内部实现非常简单,使用新的location替换历史栈中对应位置的历史记录即可:
data:image/s3,"s3://crabby-images/c9a15/c9a155674c95db6e44ce3fef67d17e4d1e7db26c" alt=""
3.history.go
memoryHistory的go方法与browserHistory、hashHistory的go方法一样,都是移动栈指针,不改变栈的内容;但其在实现上与这两者不同的是,browserHistory和hashHistory历史栈的栈指针由浏览器管理,而memoryHistory没有history.go方法可供调用以移动栈指针,所以memoryHistory自行维护栈指针,即便调用history.go方法也应自行控制栈指针。
data:image/s3,"s3://crabby-images/d7f64/d7f6455f4d3294780806cd1a6a8b57394968da86" alt=""
data:image/s3,"s3://crabby-images/737e4/737e409ce43c842dda3105bf4317a215eba3b6b5" alt=""
history.go方法对跳转距离n做了钳位控制:
data:image/s3,"s3://crabby-images/1ba1c/1ba1c29b8e1d35fb6e4e44576d5f6706e3eb5d47" alt=""
n被限制在0与history.entries.length-1之间。