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/6bc1e/6bc1e415a806aea53038ac556795a6e83d5d3886" alt=""
对于memoryHistory,其location存储在内存中,在调用history.push后,得到的location既可通过memoryHistory.location获取,也可通过访问历史栈获取:
data:image/s3,"s3://crabby-images/79125/79125e446e99eef0ed4b5bb30fc2285b525fd723" alt=""
与browserHistory、hashHistory一样,memoryHistory不仅支持调用block阻止跳转,还支持相对路径导航、保存state等:
data:image/s3,"s3://crabby-images/597b1/597b1c0d3a42fd56e7515a4f075e9c03c243a8ef" alt=""
data:image/s3,"s3://crabby-images/f2d62/f2d6262bba06bb99d9d15599d9d736caa41f32a8" alt=""
注意,在memoryHistory导航过程中,所有信息都将保存到location中,不像browserHistory的key与state一样存在于window.history.state中进行持久化存储,memoryHistory导航过程中所有的key与state均存储在自身维护的内存中。
data:image/s3,"s3://crabby-images/49a5b/49a5bbf9272d95010549784adcaf59537e693d23" alt=""
对于history.push的实现,其模拟了浏览器管理历史记录的方法:
data:image/s3,"s3://crabby-images/c151c/c151c3892f28efc566de6be77915241140c81c07" alt=""
2.history.replace
history.replace可替换历史栈内容,与browserHistory、hashHistory等均一致,其签名如下:
data:image/s3,"s3://crabby-images/b132b/b132b50c37d2f448f26e073974db7a489697b64c" alt=""
history.replace不增加栈记录:
data:image/s3,"s3://crabby-images/ca288/ca288e4ea22db409e3a795467380b340b30ad900" alt=""
对于history.replace,其内部实现非常简单,使用新的location替换历史栈中对应位置的历史记录即可:
data:image/s3,"s3://crabby-images/4a621/4a62114b198375ac38c6c90aca2063d1ce63ee0a" alt=""
3.history.go
memoryHistory的go方法与browserHistory、hashHistory的go方法一样,都是移动栈指针,不改变栈的内容;但其在实现上与这两者不同的是,browserHistory和hashHistory历史栈的栈指针由浏览器管理,而memoryHistory没有history.go方法可供调用以移动栈指针,所以memoryHistory自行维护栈指针,即便调用history.go方法也应自行控制栈指针。
data:image/s3,"s3://crabby-images/c45ba/c45ba75a1a6572672c68b7ffd781f605efe46c38" alt=""
data:image/s3,"s3://crabby-images/450ee/450ee68fa2598ee22a0e19b9d1914a8f95bfab77" alt=""
history.go方法对跳转距离n做了钳位控制:
data:image/s3,"s3://crabby-images/6e29e/6e29e3aa460b78b9fce06a91d855cff0f670f153" alt=""
n被限制在0与history.entries.length-1之间。