论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
应用中心
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
qidao123.com技术社区-IT企服评测·应用市场
»
论坛
›
软件与程序人生
›
前端开发
›
vue项目,页面刷新就404了
vue项目,页面刷新就404了
去皮卡多
论坛元老
|
2024-9-28 16:43:17
|
显示全部楼层
|
阅读模式
楼主
主题
1941
|
帖子
1941
|
积分
5823
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
在 Vue.js 项目中,如果使用了 vue-router 而且路由模式设置为 history 模式,那么在刷新页面或直接访问某个路由时,可能会遇到 404 错误。这是因为 history 模式下,前端路由的路径并不匹配服务器上的实际路径,导致服务器无法找到对应的资源。
解决方案
要解决这个问题,需要在服务器设置中将所有请求重定向到 index.html,让前端的 Vue.js 应用接管路由逻辑。
1.
Nginx 设置
如果你使用 Nginx 作为服务器,可以按照以下方式设置:
server {
listen 80;
server_name yourdomain.com;
root /path/to/your/dist; # 你的 Vue 项目打包后的静态文件路径
index index.html;
location / {
try_files $uri $uri/ /index.html;
}
}
复制代码
try_files $uri $uri/ /index.html;
:这个指令告诉 Nginx 先尝试请求的 URI,如果找不到,则返回 index.html,由前端路由处理。
2.
Apache 设置
如果你使用 Apache 作为服务器,可以创建或修改 .htaccess 文件:
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
# 如果请求的文件存在,则直接提供该文件
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
# 如果文件不存在,则重定向到 index.html
RewriteRule . /index.html [L]
</IfModule>
复制代码
3.
使用 hash 模式
如果你不想更改服务器设置,可以思量使用 Vue Router 的 hash 模式。这种模式会在 URL 中添加 #,例如 example.com/#/about。这种方式不会有刷新 404 的问题,因为 # 后的内容不会被发送到服务器。
在 router/index.js 中,将 mode 设置为 hash:
const router = new VueRouter({
mode: 'hash',
routes: [
// 你的路由配置
]
});
复制代码
总结
history 模式
:需要在服务器端设置,确保所有路由都重定向到 index.html。
hash 模式
:更简单,不需要服务器端设置,但 URL 中会有 #。
根据你的项目需求和服务器情况选择合适的解决方案。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复
使用道具
举报
0 个回复
倒序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
发新帖
回复
去皮卡多
论坛元老
这个人很懒什么都没写!
楼主热帖
如何基于 ZEGO SDK 实现 iOS 变声/混响 ...
民间最大社区,倒闭了!
FPGA虚拟化:突破次元壁的技术 ...
Ribbon负载均衡的深度分析和使用 ...
仿京东严选商城项目,集购物+支付+发货 ...
Java 结构化数据处理开源库 SPL ...
基于Kubernetes(k8s)部署Dubbo+Nacos服 ...
Python生成字母对后写入文件
LyScript 实现应用层钩子扫描器 ...
驱动开发:内核R3与R0内存映射拷贝 ...
标签云
渠道
国产数据库
集成商
AI
运维
CIO
存储
服务器
浏览过的版块
linux
MES
Java
快速回复
返回顶部
返回列表