A

1. hash路由模式

hash模式 :使用 URL 的 hash 来模拟一个完整的 URL, 其显示的网络路径中会有 “#” 号
hash 虽然出现URL中,但不会被包含在HTTP请求中,对后端完全没有影响,因此改变hash后刷新, 也不会有问题
参考:   hashChange

2. history模式

history模式: 美化后的hash模式,路径中不包含“#”。依赖于Html5 的 history api
由于改变了地址, 刷新时会按照修改后的地址请求后端, 需要后端配置处理, 将地址访问做映射, 否则会404
参考:   popState, pushState()

3. vue项目修改路由模式

改成history模式非常简单,只需要将路由的mode类型改成history即可。在 src/router/index.js

4. 在history模式下打包后的代码刷新后会报 404 报错

将history模式下打包的代码放置服务器运行,出错: 浏览器一刷新就会出现页面丢失的问题
原因
第一次发请求,浏览器默认会在url后面加个 ’ / ',访问到服务器的index.html文件,随后返index.html文件给浏览器,浏览器拿到数据后开始渲染,渲染发现index.html文件里有外链的js和css ,发起第二次请求拿到某个js文件,拿到js文件后发现发现js文件里有个逻辑,没有登录就调到login
notion image
刷新后就表示直接去服务器中找login页面,服务里面是没有login页面的,所以就会跳转404报错
notion image

5. 为什么hash模式不会出现404报错

hash模式用#号隔开,浏览器发送请求时服务器会忽略#后面的内容
notion image
notion image

6. history模式下的解决方案

解决方案:让后端配置处理, 将地址访问做映射!

为什么在开发中用history模式就不会有影响?

之所以岁月静好,是因为有人在替我们负重前行!
开发中脚手架其实已将帮我们做好了处理,所以开发中不会受影响
 
Loading...
目录
文章列表
王小扬博客
产品
Think
Git
软件开发
计算机网络
CI
DB
设计
缓存
Docker
Node
操作系统
Java
大前端
Nestjs
其他
PHP