vue-Router两种模式

前端路由概念

通过改变 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,这就为单页应用前端路由,更新视图但不重新请求页面提供了基础

posted @ 2020-10-28 13:55  林9九  阅读(134)  评论(0编辑  收藏  举报