data:image/s3,"s3://crabby-images/595b9/595b93960a85cc667ce8fd08d02bc93846d53027" alt="深入理解React Router:从原理到实践"
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人
2.2 browserHistory
2.2.1 创建browserHistory
browserHistory也叫浏览器历史对象,特点为其location的pathname、search等与浏览器中的window.location对象的各属性完全兼容。在现代浏览器中,使用browserHistory可获得最大的开发兼容性。由于开发兼容性良好,在Web浏览器场景中,browserHistory应作为首要考虑的history。创建browserHistory的方式为:
data:image/s3,"s3://crabby-images/17f09/17f09c7fe198fe8c3c87bae4553b27b60462e2e2" alt=""
对于createBrowserHistory,也可传入如下history配置:
data:image/s3,"s3://crabby-images/93070/930707316149301841ba19b4fb9724c30b960ae7" alt=""
data:image/s3,"s3://crabby-images/f77b2/f77b2f85138c4a597363aed52bdc12e1a6c5f40a" alt=""
对于browserHistory,默认的跳转不会造成页面刷新,如果设置forceRefresh为true,则在跳转过程中会强制刷新页面。
keyLength表示历史栈中栈记录的key字符串的长度,默认为6。
如果在创建history的时候传入了basename,则通过createHref、history.push和history.replace等方法都会得到basename与path的拼接。
data:image/s3,"s3://crabby-images/fb5fb/fb5fbde9d923892ca3aa404808e8af6bb18e0617" alt=""
上例中的href将为/base/path?the=query#the-hash。