前端路由概念
通过改变 URL,在不重新请求页面的情况下,更新页面视图。
Hash — 默认值,利用 URL 中的hash(“#”) 、
history– 利用URL中的路径(/home)
如何设置路由模式:
const router=new VueRouter({
mode:'history',
routes:[...]
})
mode 区别:
hash多了’#’
http://localhost:8080/#/login
history正常
http://localhost:8080/login
Hash
拥有两个方法,一个是 push, 一个是 replace
两个方法:HashHistory.push() 和 HashHistory.replace()
HashHistory.push() 将新路由添加到浏览器访问历史的栈顶
HashHistory.replace()replace()方法与push()方法不同之处在于,它并不是将新路由添加到浏览器访问历史的栈顶,而是替换掉当前的路由
History
早期History通过back()、forward()、go()等方法,我们可以读取浏览器历史记录栈的信息
从HTML5开始History提供了2个新的方法:pushState()、replaceState()
使得我们可以对浏览器历史记录栈进行修改:
pushState()
window.history.pushState(data, title, targetURL);
@状态对象:传给目标路由的信息,可为空
@页面标题:目前所有浏览器都不支持,填空字符串即可
@可选url:目标url,不会检查url是否存在,且不能跨域。如不传该项,即给当前url添加data
replaceState()
window.history.replaceState(data, title, targetURL);
@类似于pushState,但是会直接替换掉当前url,而不会在history中留下记录
特点:
这2个方法有个共同的特点:当调用他们修改浏览器历史栈后,虽然当前url改变了,但浏览器不会立即发送请求该url,这就为单页应用前端路由,更新视图但不重新请求页面提供了基础