当前位置:首页 > VUE

vue实现路由匹配

2026-03-10 07:39:03VUE

Vue 路由匹配实现方法

在 Vue 中实现路由匹配通常使用 Vue Router 库,以下是核心实现方式:

基本路由配置

安装 Vue Router 后,在 router/index.js 中配置路由:

import { createRouter, createWebHistory } from 'vue-router'

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

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

动态路由匹配

使用冒号标记动态路径参数:

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

路由参数获取

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

// 在模板中
{{ $route.params.id }}

// 在 script 中
import { useRoute } from 'vue-router'
const route = useRoute()
console.log(route.params.id)

嵌套路由

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

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

路由守卫

实现权限控制或导航守卫:

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

路由匹配模式

  1. 严格匹配:默认情况下路由不区分结尾斜杠
  2. 敏感匹配:配置 sensitive: true 使路径大小写敏感
  3. 自定义匹配:通过 pathToRegexp 选项自定义正则匹配规则

编程式导航

在组件中进行路由跳转:

import { useRouter } from 'vue-router'
const router = useRouter()

// 跳转到指定路径
router.push('/about')

// 带参数跳转
router.push({ name: 'User', params: { id: 123 } })

404 路由处理

在路由配置最后添加通配符路由:

vue实现路由匹配

{
  path: '/:pathMatch(.*)*',
  component: () => import('../views/NotFound.vue')
}

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

相关文章

vue实现单页面

vue实现单页面

Vue 实现单页面应用(SPA) Vue.js 是一个渐进式框架,非常适合构建单页面应用(SPA)。SPA 的核心特点是整个应用只有一个 HTML 页面,通过动态加载内容实现页面切换,无需重新加载整个…

vue实现访问量

vue实现访问量

Vue 实现访问量统计的方法 使用前端计数 在 Vue 中可以通过简单的计数器实现页面访问量的统计。这种方法适合小型项目或演示用途。 // 在 Vue 组件中 data() { return {…

vue实现radio

vue实现radio

Vue 实现 Radio 按钮 在 Vue 中实现 Radio 按钮可以通过 v-model 进行数据绑定,结合 input 元素的 type="radio" 属性。以下是一个基本示例: <t…

vue实现答辩

vue实现答辩

Vue 实现答辩系统的关键步骤 项目初始化与配置 使用 Vue CLI 或 Vite 创建项目,安装 Vue Router 管理路由,Pinia/Vuex 进行状态管理。配置 ESLint 和 Pre…

vue实现刷卡

vue实现刷卡

Vue 实现刷卡效果 在 Vue 中实现刷卡效果可以通过 CSS 动画和 Vue 的过渡系统结合完成。以下是一种常见的实现方式: 基础实现方法 安装 Vue 过渡依赖(如果尚未安装): npm i…

vue实现表单

vue实现表单

Vue 表单实现方法 双向数据绑定 使用 v-model 指令实现表单元素与数据的双向绑定。适用于 input、textarea、select 等元素。 <template> <…