hash模式

hash模式

#后面 hash 值的变化,并不会导致浏览器向服务器发出请求,浏览器不发出请求,也就不会刷新页面。每次 hash 值的变化,会触发hashchange 这个事件,通过这个事件我们就可以知道 hash 值发生了哪些变化,然后我们便可以监听hashchange来实现更新页面部分内容的。

hash模式背后的原理是onhashchange事件,可以在window对象上监听这个事件:(onhashchange 事件在当前 URL 的锚部分(以 '#' 号为开始) 发生改变时触发 。)

history模式

因为HTML5标准发布,多了两个 API,pushState() 和 replaceState()。通过这两个 API (1)可以改变 url 地址且不会发送请求,(2)不仅可以读取历史记录栈,还可以对浏览器历史记录栈进行修改。

除此之外,还有popState().当浏览器跳转到新的状态时,将触发popState事件.

不怕前进,不怕后退,就怕刷新,(如果后端没有准备的话),因为刷新是实实在在地去请求服务器的。(当用户刷新页面之类的操作时,浏览器会给服务器发送请求,所以这个实现需要服务器的支持,需要把所有路由都重定向到根页面。)

posted @ 2021-10-18 17:57  果果1024  阅读(326)  评论(0)    收藏  举报