当前位置:首页 > VUE

vue 路由实现

2026-01-11 20:53:54VUE

Vue 路由实现方法

Vue Router 是 Vue.js 的官方路由管理器,用于构建单页面应用(SPA)。以下是实现 Vue 路由的基本步骤:

安装 Vue Router

使用 npm 或 yarn 安装 Vue Router:

npm install vue-router
# 或
yarn add vue-router

基本配置

在项目中创建路由配置文件(通常为 router/index.js):

import { createRouter, createWebHistory } from 'vue-router';
import Home from '../views/Home.vue';
import About from '../views/About.vue';

const routes = [
  {
    path: '/',
    name: 'Home',
    component: Home
  },
  {
    path: '/about',
    name: 'About',
    component: About
  }
];

const router = createRouter({
  history: createWebHistory(),
  routes
});

export default router;

在主文件中引入路由

main.jsmain.ts 中引入并挂载路由:

import { createApp } from 'vue';
import App from './App.vue';
import router from './router';

const app = createApp(App);
app.use(router);
app.mount('#app');

路由视图与导航

在组件中使用 <router-view><router-link>

<template>
  <div>
    <router-link to="/">Home</router-link>
    <router-link to="/about">About</router-link>
    <router-view></router-view>
  </div>
</template>

动态路由

通过冒号 : 定义动态路由参数:

vue 路由实现

{
  path: '/user/:id',
  name: 'User',
  component: User
}

在组件中通过 $route.params.iduseRoute() 获取参数:

import { useRoute } from 'vue-router';

const route = useRoute();
console.log(route.params.id);

嵌套路由

通过 children 属性实现嵌套路由:

{
  path: '/user/:id',
  component: User,
  children: [
    {
      path: 'profile',
      component: UserProfile
    },
    {
      path: 'posts',
      component: UserPosts
    }
  ]
}

在父组件中使用 <router-view> 显示子路由。

vue 路由实现

路由守卫

通过路由守卫实现权限控制或导航拦截:

router.beforeEach((to, from, next) => {
  if (to.meta.requiresAuth && !isAuthenticated) {
    next('/login');
  } else {
    next();
  }
});

懒加载路由

使用动态导入实现路由懒加载:

{
  path: '/about',
  name: 'About',
  component: () => import('../views/About.vue')
}

路由元信息

通过 meta 字段传递路由元信息:

{
  path: '/admin',
  meta: { requiresAuth: true }
}

编程式导航

通过 router.pushrouter.replace 实现编程式导航:

import { useRouter } from 'vue-router';

const router = useRouter();
router.push('/about');
// 或
router.replace('/about');

以上方法涵盖了 Vue Router 的基本使用场景,可根据实际需求灵活组合。

标签: 路由vue
分享给朋友:

相关文章

vue实现triger

vue实现triger

在Vue中实现触发器(trigger)功能通常涉及自定义事件或DOM事件触发。以下是几种常见场景的实现方法: 自定义事件触发 通过$emit方法触发父组件中监听的自定义事件: // 子组件 thi…

分页实现vue

分页实现vue

分页实现(Vue) 在Vue中实现分页功能通常需要结合前端分页逻辑和后端API支持。以下是两种常见的实现方式: 前端分页实现 适用于数据量较小的情况,直接在客户端完成分页逻辑。 <templ…

vue实现动画

vue实现动画

Vue 实现动画的方法 Vue 提供了多种方式来实现动画效果,包括内置的过渡系统、第三方动画库以及直接操作 CSS 或 JavaScript 动画。 使用 Vue 内置过渡系统 Vue 的 <…

vue实现swiper

vue实现swiper

Vue 中实现 Swiper 的方法 安装 Swiper 依赖 在 Vue 项目中安装 Swiper 和相关依赖: npm install swiper vue-awesome-swiper 全局引…

vue实现addclass

vue实现addclass

Vue 实现动态添加 class 的方法 在 Vue 中动态添加 class 可以通过多种方式实现,以下是常见的几种方法: 使用对象语法 通过绑定一个对象到 :class,可以动态切换 class…

vue实现发帖

vue实现发帖

使用 Vue 实现发帖功能 前端实现 创建发帖表单组件,包含标题和内容输入框,以及提交按钮。使用 v-model 绑定表单数据。 <template> <div>…