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/0ea4b/0ea4b43a1c3c15359a78412c88f502ebe2622478" alt=""
对于createBrowserHistory,也可传入如下history配置:
data:image/s3,"s3://crabby-images/2eecd/2eecdfe34091ab06f14ab67498aefaa741706011" alt=""
data:image/s3,"s3://crabby-images/7f4b0/7f4b0be19ea597fb118be3da5840560b99f9fa59" alt=""
对于browserHistory,默认的跳转不会造成页面刷新,如果设置forceRefresh为true,则在跳转过程中会强制刷新页面。
keyLength表示历史栈中栈记录的key字符串的长度,默认为6。
如果在创建history的时候传入了basename,则通过createHref、history.push和history.replace等方法都会得到basename与path的拼接。
data:image/s3,"s3://crabby-images/45e9d/45e9d3d32b49c6d2f9947237a5d85aa5ebbde944" alt=""
上例中的href将为/base/path?the=query#the-hash。