vue-Router实现原理

前端路由概念

路由就是用来解析URL以及调用对应的控制器,在不重新请求页面的情况下,更新页面的视图

vue-Router两种模式

Hash — 默认值,浏览器#以#后的字符称为hash
history-- 利用URL中的路径(/home)

hash与history的切换
在router的index.js文件中,有一个new Router(),里面的mode默认为hash模式,可以在这里更改为history模式

const router=new VueRouter({
    mode:'history',
    routes:[...]
})

hash模式

特点

  1. hash不会被包含在http请求中,因此,改变hash不会重新加载页面
  2. hashchange 用来监听hash改变的事件
  3. 每一次改变,都会在浏览器中添加一个历史记录

方法
HashHistory.push 跳转路由,添加历史记录栈
HashHistory.replace() 跳转路由,直接替换当前页面,不会添加历史

history

特点

  1. history模式的URL要与后端的URL一样,后端如果没有对应路由,则会返回404错误
  2. popState(window.onpopstate)用来监听history改变的事件

方法
history.pushState() 跳转路由,添加历史记录栈

history.replaceState() 跳转路由,直接替换当前页面,不会添加历史

两种方式比较

  1. pushState设置的新URL可以是与当前URL同源的任意URL;而hash只可修改#后面的部分,故只可设置与当前同文档的URL

  2. pushState通过stateObject可以添加任意类型的数据到记录中;而hash只可添加短字符串

  3. pushState可额外设置title属性供后续使用

  4. history模式则会将URL修改得就和正常请求后端的URL一样,如后端没有配置对应/user/id的路由处理,则会返回404错误

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值