当前位置:首页 > 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
})

动态路由匹配

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

vue实现路由匹配

{
  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 属性实现嵌套路由:

vue实现路由匹配

{
  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 路由处理

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

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

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

相关文章

vue实现签约合作弹窗

vue实现签约合作弹窗

实现签约合作弹窗的步骤 使用Vue实现签约合作弹窗可以通过组件化方式完成,结合模态框和表单交互逻辑。以下是具体实现方法: 1. 创建弹窗组件 新建一个Vue组件文件(如SignContractDia…

vue实现muli

vue实现muli

Vue 实现多语言(i18n)支持 在 Vue 项目中实现多语言(i18n)功能,通常使用 vue-i18n 插件。以下是具体实现步骤: 安装 vue-i18n npm install vue-i…

vue实现展开

vue实现展开

展开功能的实现方法 在Vue中实现展开功能可以通过多种方式完成,常见的有使用v-show、v-if指令,结合CSS过渡动画或第三方组件库。 使用v-show控制显示隐藏 通过v-show指令可以简单…

vue实现画板

vue实现画板

Vue 实现画板功能 在 Vue 中实现画板功能可以通过 HTML5 的 Canvas API 实现。以下是一个完整的实现方案: 创建 Vue 组件 新建一个 Vue 单文件组件(SFC),命名为…

vue实现滚屏

vue实现滚屏

实现滚屏的基本方法 在Vue中实现滚屏效果可以通过多种方式完成,常见的有原生JavaScript滚动方法、第三方库或CSS动画。以下是几种常见实现方式: 使用window.scrollTo或Elem…

vue实现折叠

vue实现折叠

Vue 实现折叠功能 在 Vue 中实现折叠功能可以通过多种方式完成,以下介绍几种常见的方法。 使用 v-show 或 v-if 控制显示隐藏 通过 Vue 的指令 v-show 或 v-if 可以…