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'])