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