data:image/s3,"s3://crabby-images/595b9/595b93960a85cc667ce8fd08d02bc93846d53027" alt="深入理解React Router:从原理到实践"
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人
2.4 memoryHistory
2.4.1 创建memoryHistory
可通过调用createMemoryHistory创建memoryHistory:
data:image/s3,"s3://crabby-images/df3a7/df3a78b44fbe83f5e66791ec893c0f588b20a63e" alt=""
对于内存路由,其运行环境通常不在浏览器内,一般作为测试使用或如React Native原生环境。在创建memoryHistory时,除了history配置,如keyLength、getUserConfirmation,还可传入initialEntries、initialIndex,其声明如下:
data:image/s3,"s3://crabby-images/ad009/ad00922b3a30f118944509629e1d6a3580d7081a" alt=""
注意,basename在memoryHistory中不被支持。
initialEntries类似于Browser Router或Hash Router的历史栈,它确定了初始化的栈内容。由于是内存路由,这个历史栈仅能由history库进行记录。initialIndex表示初始的栈指针位置。它们默认的值如下:
data:image/s3,"s3://crabby-images/5efd0/5efd0d789926650fa6b5f1ee227b28118b3c1580" alt=""
initialEntries的默认值为拥有初始入口“/”的一个栈记录,initialIndex的默认值为0。
对于memoryHistory,其除了通用的history的属性,还多出index、entries和canGo属性。
data:image/s3,"s3://crabby-images/45a28/45a28320157eb0c377b5a6c806a3f33651e4bebf" alt=""
entries为历史栈数组,比起browserHistory与hashHistory,memoryHistory能获取所有的历史记录,如上一个导航地址、第一个导航地址等。index为当前历史栈指针的指针位置,需要获取当前的地址,可从history.entries[history.index]中获取,其也等价于history.location。history.length即等价于entries.length。对于memoryHistory,其canGo属性用来判断跳转位置n是否可以跳转。
data:image/s3,"s3://crabby-images/44d0d/44d0d6f5b631869bfd6af9ebf0d9b532da5dc5d9" alt=""