Vue3路由基本使用(学习笔记)


前言

vue3路由的基本使用。

一、路由文件的创建

  • Vue3中要使用vue-router的最新版本,目前是4版本。

  • 路由配置文件代码如下

import {createRouter,createWebHistory} from 'vue-router'
import Home from '@/pages/Home.vue'
import News from '@/pages/News.vue'
import About from '@/pages/About.vue'

const router = createRouter({
	history:createWebHistory(),
	routes:[
		{
			path:'/home',
			component:Home
		},
		{
			path:'/about',
			component:About
		}
	]
})
export default router

二、main.ts中进行全局注册

代码如下(示例):

import router from './router/index'
app.use(router)
app.mount('#app')

三、 路由入口RouterView的注册

注册好路由后必须要在app.vue根组件中进行视图组件的引入,要不显示不出来,路由不起效果。
代码如下(示例):

<template>
  <div class="app">
    <!-- 导航区 -->
    <div class="navigate">
      <RouterLink to="/home" active-class="active">首页</RouterLink>
      <RouterLink to="/news" active-class="active">新闻</RouterLink>
      <RouterLink to="/about" active-class="active">关于</RouterLink>
    </div>
    <!-- 一级路由的入口 -->
    <div class="main-content">
      <RouterView></RouterView>
    </div>
  </div>
</template>

<script lang="ts" setup name="App">
  import {RouterLink,RouterView} from 'vue-router'  
</script>

四、 命名路由和嵌套路由

4.1 命名路由

作用:可以简化路由跳转及传参
给路由规则命名:

routes:[
  {
    name:'home',
    path:'/home',
    component:Home
  },
  {
    name:'news',
    path:'/news',
    component:News,
  },
  {
    name:'about',
    path:'/about',
    component:About
  }
]
<!--简化前:需要写完整的路径(to的字符串写法) -->
<router-link to="/news">跳转</router-link>

<!--简化后:直接通过名字跳转(to的对象写法配合name属性) -->
<router-link :to="{name:'about'}">跳转</router-link>

4.2 嵌套路由

配置路由规则,使用children配置项:

const router = createRouter({
  history:createWebHistory(),
	routes:[
		{
			name:'home',
			path:'/home',
			component:Home
		},
		{
			name:'news',
			path:'/news',
			component:News,
			children:[
				{
					name:'detail',
					path:'detail',
					component:Detail
				}
			]
		},
		{
			name:'about',
			path:'/about',
			component:About
		}
	]
})
export default router

注意点:
1.跳转路由(记得要加完整路径):

<router-link to="/news/detail">xxxx</router-link>
<!---->
<router-link :to="{path:'/news/detail'}">xxxx</router-link>

2.二级路由创建完成后,要在你想要显示二级路由页面的地方放RouterView入口组件,一般是在Home首页中放


五、路由传参

5.1 query传参

<!-- 跳转并携带query参数(to的字符串写法) -->
<router-link to="/news/detail?a=1&b=2&address=武汉">
	跳转
</router-link>
				
<!-- 跳转并携带query参数(to的对象写法) -->
<RouterLink 
  :to="{
    //name:'detail', //用name也可以跳转
    path:'/news/detail',
    query:{
      id:news.id,
      title:news.title,
      address:news.address
    }
  }"
>
  {{news.title}}
</RouterLink>

组件中接收参数

import {useRoute} from 'vue-router'
const route = useRoute()
// 打印query参数
console.log(route.query)

5.1 params传参

<!-- 跳转并携带params参数(to的字符串写法) -->
<RouterLink :to="`/news/detail/001/参数标题/参数地址3`">{{news.title}}</RouterLink>
				
<!-- 跳转并携带params参数(to的对象写法) -->
<RouterLink 
  :to="{
    name:'deatil', //用name跳转
    params:{
      id:news.id,
      title:news.title,
      address:news.address
    }
  }"
>
  {{news.title}}
</RouterLink>

组件中接收参数

import {useRoute} from 'vue-router'
const route = useRoute()
// 打印params参数
console.log(route.params)

六、编程式导航

主要用来点击事件来跳转路由的,不用来跳转页面

import {useRoute,useRouter} from 'vue-router'

const route = useRoute()
const router = useRouter()

const Fn = () => {
	router.push('/home')  // 跳转页面
	console.log(route.query) // 获取query参数
	console.log(route.parmas) // 获取params参数
}

七、路由重定向

作用:将特定的路径,重新定向到已有路由。
简言之:就是一访问某个路径就自动跳转指定的路由

{
    path:'/',
    redirect:'/about'
}

总结

例如:以上就是今天要讲的内容,本文仅仅简单介绍了Vue3中路由的使用。

Vue3中,我们可以使用Vue Router来配置路由。下面是一个简单的示例: 1. 安装Vue Router 在终端中运行以下命令来安装Vue Router: ``` npm install vue-router@4.0.0-beta.13 ``` 2. 创建路由文件 在src文件夹中创建一个router文件夹,并在其中创建一个index.js文件。在index.js中编写以下代码: ```javascript import { createRouter, createWebHistory } from &#39;vue-router&#39; import Home from &#39;../views/Home.vue&#39; const routes = [ { path: &#39;/&#39;, name: &#39;Home&#39;, component: Home }, { path: &#39;/about&#39;, name: &#39;About&#39;, // 路由懒加载 component: () => import(/* webpackChunkName: "about" */ &#39;../views/About.vue&#39;) } ] const router = createRouter({ history: createWebHistory(process.env.BASE_URL), routes }) export default router ``` 在这个文件中,我们首先导入了Vue Router的两个函数createRouter和createWebHistory。然后定义了一个routes数组,其中包含了两个路由对象。每个路由对象都包含了path、name和component属性,分别代表路由的路径、名称和组件。其中,component属性指定了路由对应的组件,可以使用import语法来实现路由懒加载。 最后,我们使用createRouter函数创建了一个router实例,并将其导出。 3.Vue使用路由 在main.js中,我们需要将router实例挂载到Vue实例上,以便在整个应用程序中使用路由。编写以下代码: ```javascript import { createApp } from &#39;vue&#39; import App from &#39;./App.vue&#39; import router from &#39;./router&#39; createApp(App).use(router).mount(&#39;#app&#39;) ``` 在这个文件中,我们首先导入了createApp函数和App组件。然后导入了router实例,并使用createApp函数创建了一个Vue实例,并将router实例注册到该实例上。 现在,我们就可以在应用程序中使用Vue Router了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值