data:image/s3,"s3://crabby-images/595b9/595b93960a85cc667ce8fd08d02bc93846d53027" alt="深入理解React Router:从原理到实践"
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人
1.4.2 hashchange事件
hashchange事件用于监听浏览器hash值的变化,其监听方式为
data:image/s3,"s3://crabby-images/01fec/01fec4471c77f4c4c9406f57b65e74f987ca1958" alt=""
hashchange事件可以通过设置location.hash、在地址栏中手动修改hash、调用window.history.go、在浏览器中单击“前进”或“后退”按钮等方式触发。
在hashchange事件的事件响应函数中,可获取事件对象HashChangeEvent,其除了继承事件对象Event,拥有Event的属性,如target、type,还提供oldURL、newURL,分别表示hash跳转前的URL及hash跳转后的URL。
data:image/s3,"s3://crabby-images/72729/727296312f56608902a927d4d20b392a28aa8705" alt=""
data:image/s3,"s3://crabby-images/f74c4/f74c4f87996f613db32becb81a6897f67f40848b" alt=""
注意,window.history.pushState不会触发hashchange事件,即使前后导航的URL仅hash部分不同,也是如此,如:
data:image/s3,"s3://crabby-images/14e23/14e23f9dc951617ea1165e1e4163d67fed357860" alt=""