hash模式和history模式对比

功能:vue项目是单页面应用,仅存在一个html物理文件,通过路由系统可以将项目的组件与可访问的url路径进行绑定,切换页面时既需要让访问的url路径变化,又不能触发html物理文件的重新加载

直观区别:对于hash模式和history模式,最直接的区别就是地址栏带不带"#"号了。

hash模式:

在调试窗口输入Window.loacation(包含了浏览器地址栏的地址信息)可以看到hash的变化,中文没法正常显示

hash模式是观察window.location.hash的变化来改变路由的。

纯静态技术,路由的哈希模式其实是利用了window.onhashchange事件,也就是哈希值(#后面的值)如果有变化,就会自动调用hashchange的监听事件,在hashchange的监听事件内可以得到改变后的url,通知触发函数,实现快速的dom组件的切换

匹配路径,找对应的组件,找到以后把它添加到dom里面,或者display显示或者隐藏

缺点:分布式项目(每个人写一个项目,网页部署在不同的服务器上,一个url路径只能有一个#)

history模式:

底层:利用history本身的pushState()重写url路径

利用点击事件中history的pushState重写页面路径,重写完之后再去加载dom对象

缺点

对于单页面应用,history确实会跳转到对应的响应式页面,同时路由url也会变化,但是当刷新时,重新向服务器请求数据,会出现404。

原因是服务器找不到对应的文件。

vueCli开发模式已经解决了这个问题,但是到生产模式中会出现问题。

那么如何解决呢?这就需要服务器端做点手脚,将不存在的路径请求重定向到入口文件(index.html)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值