当前位置:首页 > VUE

vue路由实现

2026-03-27 12:45:11VUE

Vue 路由实现方法

Vue Router 是 Vue.js 的官方路由管理器,用于构建单页面应用(SPA)。以下是实现 Vue 路由的核心步骤和配置方法。

安装 Vue Router

通过 npm 或 yarn 安装 Vue Router:

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

基本配置

在项目中创建路由配置文件(通常为 router/index.js),引入 Vue Router 并定义路由规则:

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

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

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

export default router

挂载路由

main.js 中导入路由实例并挂载到 Vue 应用:

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路由实现

const routes = [
  { path: '/user/:id', component: User }
]

在组件中通过 useRoute 获取参数:

import { useRoute } from 'vue-router'

export default {
  setup() {
    const route = useRoute()
    console.log(route.params.id)
  }
}

导航守卫

通过路由守卫控制导航行为(如权限验证):

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

懒加载路由

使用动态导入实现路由懒加载,优化性能:

vue路由实现

const routes = [
  { path: '/', component: () => import('../views/Home.vue') }
]

嵌套路由

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

const routes = [
  {
    path: '/user',
    component: User,
    children: [
      { path: 'profile', component: Profile }
    ]
  }
]

父组件需包含 <router-view> 占位符。

路由模式

Vue Router 支持两种历史模式:

  • createWebHistory: HTML5 模式(需服务器配置)
  • createWebHashHistory: Hash 模式(URL 带 #

命名路由与编程式导航

通过 name 属性定义命名路由,使用 router.push 跳转:

const routes = [
  { path: '/user', name: 'user', component: User }
]

// 组件内跳转
import { useRouter } from 'vue-router'
const router = useRouter()
router.push({ name: 'user' })

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

相关文章

vue实现3d宇宙

vue实现3d宇宙

Vue实现3D宇宙效果 使用Three.js库 Three.js是一个强大的JavaScript 3D库,可以轻松集成到Vue项目中。安装Three.js依赖: npm install three…

vue实现选中单元格

vue实现选中单元格

Vue 实现选中单元格的方法 基础实现思路 在 Vue 中实现选中单元格功能,通常可以通过动态绑定 class 或 style 来实现。以下是一个基于表格的简单实现示例: <template&…

vue实现盖章

vue实现盖章

Vue 实现盖章功能 在Vue中实现盖章功能通常涉及前端UI交互,通过Canvas或SVG绘制印章,并允许用户拖拽或点击放置印章。以下是具体实现方法: 使用Canvas绘制印章 通过HTML5的Ca…

vue实现骰子

vue实现骰子

Vue 实现骰子功能 创建 Vue 组件 在 Vue 项目中创建一个骰子组件,例如 Dice.vue。该组件包含骰子的外观和逻辑。 <template> <div class=…

tabbar 实现 vue

tabbar 实现 vue

在 Vue 中实现 TabBar 功能可以通过多种方式完成,以下是几种常见的方法: 使用 Vue Router 结合自定义组件 创建一个自定义的 TabBar 组件,结合 Vue Route…

vue实现快手

vue实现快手

Vue 实现类似快手的功能 Vue.js 是一个渐进式 JavaScript 框架,适合构建复杂的单页应用。要实现类似快手的功能,可以结合 Vue 和相关技术栈进行开发。 核心功能模块 视频流展示…