解决Vue应用中遇到路由刷新后出现 404 错误

解释:

Vue 应用中遇到路由刷新后出现 404 错误,通常是因为 Vue 应用是个单页应用(SPA),它通过 Vue Router 管理路由,通过 HTML5 History Mode 实现页面导航无需重新加载页面。当直接访问非首页的路由或者刷新页面时,服务器会尝试寻找对应的真实物理路径,找不到就会返回 404 错误。

解决方法:

  1. 服务器配置:需要配置服务器,使其可以正确处理所有路由请求,并返回同一个index.html页面。

对于不同的服务器,配置方法如下:

对于 Apache: 在服务器的配置文件(通常是.htaccess文件)中添加以下规则:
*

复制代码
  <IfModule mod_rewrite.c>
    RewriteEngine On
    RewriteBase /
    RewriteRule ^index\.html$ - [L]
    RewriteCond %{REQUEST_FILENAME} !-f
    RewriteCond %{REQUEST_FILENAME} !-d
    RewriteRule . /index.html [L]
  </IfModule>

对于 Nginx: 在 Nginx 配置文件中添加如下配置:
*

复制代码
  location / {
    try_files $uri $uri/ /index.html;
  }

对于 Node.js: 如果你使用的是 Node.js 的 Express 服务器,可以添加以下路由来捕获所有路由请求并返回index.html

复制代码
  app.get('*', (req, res) => {
    res.sendFile(path.resolve(__dirname, 'public', 'index.html'));
  });
  • 使用 Hash Mode:另一种方法是使用 Vue Router 的 Hash Mode,它不需要服务器端的特别配置。在 Vue Router 中设置mode: 'hash'即可启用。

  • 例如,在 Vue 应用的入口文件main.js中配置 Vue Router:

复制代码
  import Vue from 'vue';
  import VueRouter from 'vue-router';
  import App from './App.vue';
   
  Vue.use(VueRouter);
   
  const router = new VueRouter({
    mode: 'hash', // 启用 hash mode
    routes: [
      // 定义路由
    ]
  });
   
  new Vue({
    router,
    render: h => h(App)
  }).$mount('#app');

选择合适的方法进行配置,即可解决 Vue 应用在路由刷新时出现的 404 错误。

相关推荐
m0_471199632 分钟前
【自动化】前端开发,如何将 Jenkins 与 Gitee 结合实现自动化的持续集成(构建)和持续部署(发布)
前端·gitee·自动化·jenkins
w***95493 分钟前
spring-boot-starter和spring-boot-starter-web的关联
前端
Moment7 分钟前
富文本编辑器技术选型,到底是 Prosemirror 还是 Tiptap 好 ❓❓❓
前端·javascript·面试
xkxnq12 分钟前
第二阶段:Vue 组件化开发(第 18天)
前端·javascript·vue.js
晓得迷路了13 分钟前
栗子前端技术周刊第 112 期 - Rspack 1.7、2025 JS 新星榜单、HTML 状态调查...
前端·javascript·html
怕浪猫16 分钟前
React从入门到出门 第五章 React Router 配置与原理初探
前端·javascript·react.js
jinmo_C++16 分钟前
从零开始学前端 · HTML 基础篇(一):认识 HTML 与页面结构
前端·html·状态模式
鹏多多22 分钟前
前端2025年终总结:借着AI做大做强再创辉煌
前端·javascript
哈__25 分钟前
React Native 鸿蒙跨平台开发:Vibration 实现鸿蒙端设备的震动反馈
javascript·react native·react.js
WebGISer_白茶乌龙桃28 分钟前
Cesium实现“悬浮岛”式,三维立体的行政区划
javascript·vue.js·3d·web3·html5·webgl