vue-router 两种模式的区别

vue-router有两种模式,hash模式和history模式,这里来谈谈两者的区别。

**hash模式**
hash模式背后的原理是onhashchange事件,可以在window对象上监听这个事件:

> window.onhashchange = function(event){

>     console.log(event.oldURL, event.newURL);
>     let hash = location.hash.slice(1);
>     document.body.style.color = hash;
> }

上面的代码可以通过改变hash来改变页面字体颜色,虽然没什么用,但是一定程度上说明了原理。

更关键的一点是,因为hash发生变化的url都会被浏览器记录下来,从而你会发现浏览器的前进后退都可以用了,同时点击后退时,页面字体颜色也会发生变化。这样一来,尽管浏览器没有请求服务器,但是页面状态和url一一关联起来,后来人们给它起了一个霸气的名字叫前端路由,成为了单页应用标配。


网易云音乐,百度网盘就采用了hash路由,看起来就是这个样子:

> http://music.163.com/#/friend
> https://pan.baidu.com/disk/home#list/vmode=list


2.history模式
主要使用HTML5的pushState()和replaceState()这两个api来实现的,pushState()可以改变url地址且不会发送请求,replaceState()可以读取历史记录栈,还可以对浏览器记录进行修改

这两个方法应用于浏览器的历史记录站,在当前已有的back、forward、go 的基础之上,它们提供了对历史记录进行修改的功能。只是当它们执行修改是,虽然改变了当前的URL,但你浏览器不会立即向后端发送请求。

> window.history.pushState(stateObject, title, URL)
> window.history.replaceState(stateObject, title, URL) 
> 包括back,forward ,go 三个方法

>history.go(-2);//后退两次 
>history.go(2);//前进两次 
>history.back(); //后退
>hsitory.forward(); //前进

区别:
前面的hashchange,你只能改变#后面的url片段。而pushState设置的新URL可以是与当前URL同源的任意URL。
history模式则会将URL修改得就和正常请求后端的URL一样,如后端没有配置对应/user/id的路由处理,则会返回404错误

了解更多前端课程内容欢迎关注小编!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值