HTML5History
HTML5History模式的vue-router 代码结构以及更新视图的逻辑与hash模式基本类似,和HashHistory的步骤基本一致,只是HashHistory的push和replace()变成了HTML5History.pushState()和HTML5History.replaceState()
在HTML5History中添加对修改浏览器地址栏URL的监听是直接在构造函数中执行的,对HTML5History的popstate 事件进行监听:
constructor (router: Router, base: ?string) { window.addEventListener('popstate', e => {
const current = this.current
this.transitionTo(getLocation(this.base), route => {
if (expectScroll) {
handleScroll(router, route, current, true)
}
})
})
}
以上就是vue-router hash模式与history模式不同模式下处理逻辑的分析了。
总结
以上所述是小编给大家介绍的vue-router实现原理及两种模式分析,希望对大家有所帮助!










