一. hasChange 触发条件
hash是URL中#后面那部分,同时修改hash值不会引起页面的刷新,也不会向服务器重新发送请求。通过hashchange事件可以监听它的变化。改变hash值有以下三种方式:
- 浏览器前进后退改变URL
- 通过a标签锚点方式改变URL。
- 通过window.location.hash改变URL
- 调用history的back、go、forward方法
不能触发事件的方式
- pushState和replaceState
备注:以上三种方式均可以触发hashchang事件, pushState和replaceState均不能触发hashchang事件
二. popstate触发条件
history提供了popstate监听事件,但是只有以下两种情况会触发该事件
- 点击浏览器前进后退的按钮
- 显示调用history的back、go、forward方法
不能触发事件的方式
- pushState和replaceState
- a标签不能触发,因为非锚点模式直接跳转了页面。