vue.js

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > vue.js > vue hash vs history区别

Vue 项目部署在子目录下时hash vs history 的真实区别解析

作者:Knight_AL

Vue子目录部署中,hash模式稳定且无需后端配合,而history模式需要后端支持否则容易出问题,子目录部署下,hash模式天生安全且页面刷新不会404,而history模式需要正确配置Nginx才能正常工作,本文给大家介绍Vue部署在子目录下时hash vs history区别,感兴趣的朋友一起看看吧

在 Vue 项目部署中, 子目录部署是一个非常常见、但也非常容易踩坑的场景,例如:

http://ip:port/wvp/

而不是默认的:

http://ip:port/

这时,Vue Router 的 hash 模式history 模式 在行为上会出现本质区别

一、先说结论

在子目录(如 /wvp/)下部署 Vue 项目:

如果是内部系统 / 后台管理系统强烈推荐 hash 模式

二、hash 和 history 的 URL 本质区别

1️⃣ hash 模式

/wvp/#/dashboard

特点:

2️⃣ history 模式

/wvp/dashboard

特点:

三、子目录 + hash:为什么几乎不会出问题?

访问流程解析

当访问:

http://ip:port/wvp/#/dashboard

浏览器与服务器的交互是:

浏览器请求 → /wvp/
服务器返回 → index.html
Vue Router 解析 → #/dashboard

👉 服务器永远只看到 /wvp/

hash 模式的优势

📌 子目录部署下,hash 模式天生安全

四、子目录 + history:为什么容易翻车?

访问流程解析

访问:

http://ip:port/wvp/dashboard

服务器接收到的是:

/wvp/dashboard

如果服务器没有配置该路径:

→ 找不到资源
→ 返回 404

❌ 页面刷新 404
❌ 浏览器直接访问 404
❌ 前进 / 后退偶发 404

五、history 模式在子目录下必须做哪些配置?

1️⃣ 前端配置(缺一不可)

// vue.config.js
module.exports = {
  publicPath: '/wvp/'
}
// router/index.js
const router = new VueRouter({
  mode: 'history',
  base: '/wvp/',
  routes
})

2️⃣ Nginx / 后端配置(核心)

Nginx 示例

location /wvp/ {
  try_files $uri $uri/ /wvp/index.html;
}

含义:

如果没有这一步会怎样?

/wvp/dashboard → Nginx找文件 → 找不到 → 404

六、hash vs history:子目录下的真实对比

对比项hash 模式history 模式
子目录部署✅ 非常稳⚠️ 易翻车
是否依赖后端❌ 不需要✅ 必须
页面刷新✅ 永不 404❌ 不配就 404
URL 美观❌ 有 #✅ 干净
SEO❌ 差✅ 好
运维成本⭐ 低⭐⭐⭐ 高

七、什么时候才应该用 history?

否则:

子目录部署 + 内部系统 → hash 是最优解

八、推荐配置(子目录)

// vue.config.js
module.exports = {
  publicPath: '/wvp/'
}
// router/index.js
export default new VueRouter({
  mode: 'hash',
  base: '/wvp/',
  routes
})

✅ 不依赖后端
✅ 刷新不炸
✅ 部署简单

九、总结

hash 是“工程优先”
history 是“美观优先”

在子目录部署场景下,稳定永远比好看重要

到此这篇关于Vue 项目部署在子目录下:hash vs history 的真实区别的文章就介绍到这了,更多相关vue hash vs history区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文