当前位置:首页 > VUE

vue的路由实现

2026-02-17 08:17:04VUE

Vue 路由实现方式

Vue 路由主要通过 vue-router 库实现,用于构建单页面应用(SPA)。以下是核心实现方法和步骤:

安装 vue-router

通过 npm 或 yarn 安装:

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

基本配置

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

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

const routes = [
  {
    path: '/',
    name: 'Home',
    component: Home
  },
  {
    path: '/about',
    name: 'About',
    component: () => import('../views/About.vue') // 懒加载
  }
]

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

export default router

挂载路由

main.js 中挂载路由实例:

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>

动态路由

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

{
  path: '/user/:id',
  name: 'User',
  component: () => import('../views/User.vue')
}

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

import { useRoute } from 'vue-router'

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

导航守卫

实现路由跳转前的逻辑控制:

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

路由模式

支持两种历史记录模式:

  • createWebHistory: 基于 HTML5 History API(无 #
  • createWebHashHistory: 基于 URL hash(带 #
const router = createRouter({
  history: createWebHashHistory(), // 或 createWebHistory()
  routes
})

嵌套路由

通过 children 属性实现嵌套视图:

{
  path: '/user',
  component: UserLayout,
  children: [
    {
      path: 'profile',
      component: UserProfile
    }
  ]
}

父组件中需嵌套 <router-view>

<template>
  <div>
    <h1>User Layout</h1>
    <router-view></router-view>
  </div>
</template>

路由元信息

通过 meta 字段传递自定义数据:

vue的路由实现

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

以上方法覆盖了 Vue 路由的核心功能,可根据实际需求组合使用。

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

相关文章

vue插件实现

vue插件实现

Vue 插件实现方法 Vue 插件是一种向 Vue 应用程序添加全局功能的机制。插件可以包含全局指令、过滤器、混入、实例方法等。 插件的基本结构 一个 Vue 插件通常是一个对象或函数,需要暴露一个…

vue实现groupbox

vue实现groupbox

Vue 实现 GroupBox 组件 在 Vue 中实现类似 GroupBox 的效果可以通过自定义组件完成。GroupBox 通常是一个带有标题的边框容器,用于将相关控件分组显示。 基本实现方法…

vue实现popover

vue实现popover

Vue 实现 Popover 的方法 使用第三方库(如 Element UI、Ant Design Vue) 许多成熟的 UI 库已经内置了 Popover 组件,可以直接调用。 Element U…

vue实现搜索提示

vue实现搜索提示

Vue实现搜索提示的方法 使用v-model绑定输入框 通过v-model将输入框的值与Vue实例中的数据进行双向绑定,实时获取用户输入内容。 <input v-model="searchQu…

vue实现全选下载

vue实现全选下载

Vue实现全选下载功能 全选下载功能通常涉及前端文件列表的多选操作和批量下载逻辑。以下是基于Vue的实现方案: 数据准备与渲染 在Vue组件中定义文件列表数据和选中状态: data() { r…

vue视频怎么实现

vue视频怎么实现

实现视频播放功能 在Vue中实现视频播放功能可以通过HTML5的<video>标签或第三方库来实现。以下是几种常见的方法: 使用HTML5 <video>标签 <te…