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/8731b/8731b52e919b063a352402e3fb5afccdc2627c2e" alt=""
对于memoryHistory,其location存储在内存中,在调用history.push后,得到的location既可通过memoryHistory.location获取,也可通过访问历史栈获取:
data:image/s3,"s3://crabby-images/13d3a/13d3a5d870269c424066ad425271bd5401678483" alt=""
与browserHistory、hashHistory一样,memoryHistory不仅支持调用block阻止跳转,还支持相对路径导航、保存state等:
data:image/s3,"s3://crabby-images/34288/34288e51a8a249eb2798ccf57b2e8674be8ff225" alt=""
data:image/s3,"s3://crabby-images/67d9d/67d9d5a59fc3bd01f2c402ac2f905c3a7efb1c62" alt=""
注意,在memoryHistory导航过程中,所有信息都将保存到location中,不像browserHistory的key与state一样存在于window.history.state中进行持久化存储,memoryHistory导航过程中所有的key与state均存储在自身维护的内存中。
data:image/s3,"s3://crabby-images/a1887/a1887888fe6d0142e74e2ad44f01430a619cead3" alt=""
对于history.push的实现,其模拟了浏览器管理历史记录的方法:
data:image/s3,"s3://crabby-images/abf6e/abf6ebfaabf4057bc2f6dca666ced9ee481e9a00" alt=""
2.history.replace
history.replace可替换历史栈内容,与browserHistory、hashHistory等均一致,其签名如下:
data:image/s3,"s3://crabby-images/5d816/5d81680c1a47eb59cc03d0a694c64bd5a726eedd" alt=""
history.replace不增加栈记录:
data:image/s3,"s3://crabby-images/87dc7/87dc7896a9784f8f63dc03b6bd6ba9873c53fcb9" alt=""
对于history.replace,其内部实现非常简单,使用新的location替换历史栈中对应位置的历史记录即可:
data:image/s3,"s3://crabby-images/bfc40/bfc40cde03def81368b5e576523e08df76210466" alt=""
3.history.go
memoryHistory的go方法与browserHistory、hashHistory的go方法一样,都是移动栈指针,不改变栈的内容;但其在实现上与这两者不同的是,browserHistory和hashHistory历史栈的栈指针由浏览器管理,而memoryHistory没有history.go方法可供调用以移动栈指针,所以memoryHistory自行维护栈指针,即便调用history.go方法也应自行控制栈指针。
data:image/s3,"s3://crabby-images/65486/65486cded655dc13ba3ede550cc4762b8a1b7328" alt=""
data:image/s3,"s3://crabby-images/09854/0985410c2a97368524454548b5aa8f3d868133c5" alt=""
history.go方法对跳转距离n做了钳位控制:
data:image/s3,"s3://crabby-images/04863/04863986ea432f82bf7dbfbdbfd943f7a8514189" alt=""
n被限制在0与history.entries.length-1之间。