Vue3中的vue-router的基本使用

1、vue3的vue-router与vue2中的vue-router,区别不大,主要区别在引入方式上。

TypeScript 复制代码
import { createRouter, createWebHashHistory } from 'vue-router'
import show from '../components/show.vue'

const router = createRouter({
  history: createWebHashHistory(),
  routes: [
    {
      path: '/',
      redirect:'/home'
    },
    {
      path: '/home',
      name: 'home',
      component: home,
      children:[
          {
            path: 'tab/:id/:name',
            name: 'tab',
            component: tab,
            props:true
          }
      ]
    }
  ]
})

export default router

2、命名式导航使用路由。

TypeScript 复制代码
import { RouterView,RouterLink } from "vue-router";
//组件中直接使用即可
<RouterLink :to="/home">点击跳转</RouterLink>
<RouterLink :to="/home/tab">点击跳转</RouterLink>
<RouterLink :to="{name:'home'}">点击跳转</RouterLink>
<RouterLink :to="{name:'tab',params:{id:1,name:'张三'}}">点击跳转</RouterLink>
<RouterView></RouterView>

3、编程式导航使用路由。

TypeScript 复制代码
//导入useRouter
import {useRouter} from 'vue-router'
//创建实例
const router = usrRouter()
//实现路由跳转
router.push('/home')
//router.replace(`/home/tab/${id}`)
//router.push({name:'home'})
//router.push({name:'tab'})

3、针对动态路由匹配的取值方式有细微区别。

TypeScript 复制代码
//在组件中直接使用,前提是路由规则中开启props:true
defineProps(['id','name'])
相关推荐
伍哥的传说7 分钟前
Vue3 响应式翻牌抽奖游戏
javascript·vue.js·游戏·前端框架·vue·交互
涛々17 分钟前
uniapp-vue3-js-vite-pinia-eslint 快速开发模板
javascript·uni-app·uniapp+vue3模板
解道Jdon27 分钟前
最新苹果液体玻璃Liquid Glass效果CSS实现
javascript·reactjs
啊~哈1 小时前
页面弹窗适配问题
前端·javascript·vue.js
工呈士1 小时前
构建优化策略:Tree Shaking、代码分割与懒加载
前端·面试
用户327324209871 小时前
logger2js - JavaScript日志与调试工具库
javascript
骑自行车的码农1 小时前
React Suspense实现原理深度解析 1
前端·react.js
安然dn1 小时前
Interact.js 一个轻量级拖拽库
javascript
还是一只小牛1 小时前
探秘 React Native:线程探索及桥优化
android·前端
Face1 小时前
Vue源码核心模块解析
前端·vue.js