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'])
相关推荐
爱勇宝26 分钟前
小红花成长新版:模板来了,鼓励也更容易开始
前端·后端·程序员
竹林8181 小时前
Solana前端开发:我在一个NFT铸造页面上被@solana/web3.js的Connection和Transaction签名坑了两天
前端
冬奇Lab1 小时前
每日一个开源项目(第144篇):ai-website-cloner-template - 一条命令、多 Agent 并行,把任意网站逆向成 Next.js 代码
前端·人工智能·开源
玄玄子2 小时前
webpack publicPath作用原理
前端·webpack·程序员
HduSy2 小时前
帮 Claude Code 做了个菜单栏 Token 看板,聊聊里面的一些实现逻辑
前端
minglie2 小时前
一个置换问题
javascript
用户059540174462 小时前
用了6个月LangChain,才发现AI Agent的记忆存储一直有坑——写了23个Pytest用例才彻底修好
前端·css
奶油mm2 小时前
我偷偷把公司的祖传 jQuery 项目改成了 Vue3,CTO 没发现,但全组都来抄我的代码了
前端
用户2136610035722 小时前
Vue2非父子通信与动态组件
前端·vue.js
默_笙2 小时前
🌀 别再手动写 Prompt 了!我让 AI 自己循环改到满意为止
javascript