search

Home  >  Q&A  >  body text

Dynamic routing in Vue 3 + Vite development server causes 404 error on page reload

In my project I use Vue 3.2.36 Vite 2.9.9 VueRouter 4.1.3

I run the development server using npm run dev.

My route definition:

routes: [
    {
      path: '/',
      component: Home,
    },
    {
      path: '/about',
      component: () => import('@/views/About.vue'),
    },
    {
      path: '/user-details/:login',
      name: 'userDetails',
      component: () => import('@/views/User.vue'),
    },
    {
      path: '/:pathMatch(.*)*',
      component: NotFound,
    }
  ],

When I navigate programmatically using router.push({name: 'userDetails', params: {login: 'john.smith'}}) the userDetails page /Component displays correctly.

But if my browser reloads the development server returns 404 and the NotFound component does not show up.

Chrome:


FF:


Working example: here

I've isolated the issue to Vite. Everything works fine using the Vue CLI.

My vite.config.js:

import loadVersion from 'vite-plugin-package-version';

import { defineConfig } from 'vite';
import vue from '@vitejs/plugin-vue';

export default defineConfig(() => {
  return {
    server: {
      port: 8080,
    },
    plugins: [vue(), loadVersion()],
    resolve: {
      alias: {
        '@': fileURLToPath(new URL('./src', import.meta.url)),
      },
    },
    envDir: './src/configuration',
    css: {
      preprocessorOptions: {
        scss: {
          additionalData: '@import "@/assets/scss/_variables.scss";',
        },
      },
    },
  };
});

Checked my index.html:


Checked the vue-router historical mode documentation and in the warnings section it states that the router should default to index.html if the route is not found, and that it uses the Vue CLI to do this, But don't do this with Vite.

P粉811329034P粉811329034440 days ago1081

reply all(2)I'll reply

  • P粉757556355

    P粉7575563552023-10-28 00:56:43

    My web application is on Azure DevOps but on Linux For Linux web applications, you must add the next command to run the web application command on startup. This works for me.

    pm2 serve /home/site/wwwroot --no-daemon --spa

    You can see more in this article Azure webapp React application on linux

    reply
    0
  • P粉011684326

    P粉0116843262023-10-28 00:30:48

    Yes, it's aware of the bug in Vite.
    The solution is to use plugins in Vite as described here

    For me, this is a no-no. I'm going to switch to Vue CLI.
    I don't want to deal with this kind of little monster.
    I will visit Vite again in a few years.

    reply
    0
  • Cancelreply