data:image/s3,"s3://crabby-images/595b9/595b93960a85cc667ce8fd08d02bc93846d53027" alt="深入理解React Router:从原理到实践"
1.2.2 history.replaceState
1.基本用法
history.replaceState的用法与history.pushState非常相似,区别在于history.replaceState将修改当前的历史记录项而不是新建一个。其语法为:
data:image/s3,"s3://crabby-images/b0afb/b0afb50ad1e1abda7b3ff8d46dbf77d0c9c0a3e2" alt=""
当需要更新当前栈指针所指向的栈记录,而不是增加历史栈时,可使用history.replaceState方法,该方法不会使history.length发生变化。
data:image/s3,"s3://crabby-images/2fca8/2fca83a3fd671248ce106cdb871a9d27409cb6dc" alt=""
同history.pushState方法类似,history.replaceState方法也可传递state到历史栈的栈记录中。
data:image/s3,"s3://crabby-images/5d9d4/5d9d4710433cdd32de599f2fb06d63a5020a6e0e" alt=""
对于state对象,history.replaceState同history.pushState一样使用结构化拷贝算法,如对象中不能设置函数:
data:image/s3,"s3://crabby-images/2e9dc/2e9dc34da6849cbf4865b836b59b880afb159985" alt=""
2.历史栈变化
history.replaceState不会改变历史栈中记录的数量,如图1-3所示,当位于路径/b时,调用history.replaceState({a:3},null,'/c')方法会更新当前栈的信息,栈记录/b会被替换为/c,此时/b的记录会丢失,栈的记录数量不会发生变化。
data:image/s3,"s3://crabby-images/c03ec/c03ecd009092352c9159f2ee5124df3511321634" alt=""
图1-3 history.replaceState更新历史栈栈顶记录
data:image/s3,"s3://crabby-images/32314/3231488a794a0954eb33c12838d9f96b18336828" alt=""
如果当前的栈指针指向栈中间的记录,则此时调用history.replaceState方法,仅改变当前栈指针所指向的记录,如图1-4所示。
data:image/s3,"s3://crabby-images/269bd/269bd06e5abf36ca519537837b9d80f3e96023e3" alt=""
图1-4 history.replaceState更新非栈顶记录
/b的记录被替换为/c的记录,栈顶的/d记录不受影响,且栈指针依然位于中间位置。
history.replaceState与history.pushState的主要不同是,history.replaceState会替换当前指针位置的历史记录,并不会移动指针,也不会入栈新内容,history.length不会发生变化。