好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

Vue3路由配置createRouter、createWebHistory、useRouter和us

前言

Vue3和Vue2基本差不多,只 不过 需要将 createRouter 、 createWebHistory 从 vue-router 中引入,再进行使用。

手动配置Vue-router环境:

1、下载包: npm i vue-router - -s ave 或者 npm i vue-router --S&nbs p;   或者用cdn引入

2、创建路由的js文件(路由、子路由、重定向、开启history模式)

      createRouter、createWebHistory

//路由文件
import { createRouter, createWebHistory }  From  'vue-router'  //将createRouter、createWebHistory引入vue
const routes = [
  {
    path: '/',  //配置默认路由
    n am e: 'home', //路由名
     component : () => import(" .. /views/home.vue"), //引入该路由使用的组件
  
  },
  {
    path: '/a',
	
    name: 'a',
    component: () => import('views/a.vue'),
	 red irect: '/a/so n1 ',
	children:[ //配置子路由
		{
		path: '/a/son1', //子路由路径前边必须写父路由路径
		name: 'ason1',
		component: ()=>import("views/a-son1.vue")	
		}
	]
  },
  {
    path: '/b',
  	
    name: 'b',
    component: () => import('views/b.vue'),
  	redirect: '/b/son1', //重定向,进入/b路由时默认进入/b/son1
  	children:[ //配置子路由
  		{
  		path: '/b/son1', //子路由路径前边必须写父路由路径
  		name: 'bson1',
  		component: ()=>import("views/b-son1.vue")	
  		}
  	]
  }
]
const router = createRouter({ //设置为history模式
  history: createWebHistory(),
  routes
})
 export  default router

3、将配置的路由js文件引入到m ai n.js中

import { createApp } f rom  'vue'
import App from './App.vue'
 
const app=createApp(App)
 
import router from "./router/index.js" //引入配置路由文件
app.use(router)//记得在 mount 之前调用
 
app.mount(' # app')

4、界面中使用 router-view 标签显示路由

组件内部跳转路由、传参useRouter,useRoute

vue3中,在组件内部跳转路由 需要使用 useRouter , useRoute 方法

useRoute 相当于以前的this.$route 跳转路由

用法:

<template>
	< h1 >aaa</h1>
	<router-view></router-view>
	<button @click="fn">从a路由跳转到b路由</button>
</template>
 
<script  SETUP >
	import {useRouter} from "vue-router"
	    let router=useRouter() //接收useRouter方法,在vue2中是直接使用router即可
	
		let fn=()=>{
	        
			router.push({path:"/b",query:{name:"小狮子"}}) //path写跳转的路由,同样可以传参
		}
	    
</script>
 
<style sco PE d>
	h1{
		width: 400px;
	    h ei ght:200px;
		background-color:deeppink;
	}
</style>

useRouter 相当于this. $router   接受传参(query、params)

注意:1、 请注意params只与 name(路由文件里配置的路由name) 搭配 生效 (不能使用path)

        2、只能在setup函数内使用

用法

<template>
	<h2>这是b-son1</h2>
	<button @click="fn">lookquery</button>
</template>
 
<script setup>
	import {useRoute} from "vue-router" //引入
	let route=useRoute()
	 console. LOG (route.query)//如果是params传参就用route.params接收
 
let fn=()=>{  //这不是setup函数内部,是取不到传参的,返回un define d
		let route=useRoute()
		 console.log(route)
	}
	
</script>
 
<style scoped>
	h2{
		width: 200px;
	    height:100px;
		background-color:aliceblue;
	}
</style>

结合前者代码进行验证,发现下图状况

当我们进行页面跳转时成功获取了传参,但不在 setup函数内 使用 useRouter 是获取不了的

总结

到此这篇关于Vue3路由配置createRouter、createWebHistory、useRouter和useRoute的 文章 就介绍到这了,更多相关Vue3手动配置Vue-router环境内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

您可能感兴趣的文章: vue动态路由配置及路由传参的方式 使用vue-router为每个路由配置各自的title vue 开发之路由配置方法详解 Vue结合路由配置递归实现菜单栏功能 Vue中的路由配置项meta使用解析 深入理解Vue-cli4路由配置

总结

以上是 为你收集整理的 Vue3路由配置createRouter、createWebHistory、useRouter和useRoute详解 全部内容,希望文章能够帮你解决 Vue3路由配置createRouter、createWebHistory、useRouter和useRoute详解 所遇到的问题。

如果觉得 网站内容还不错, 推荐好友。

查看更多关于Vue3路由配置createRouter、createWebHistory、useRouter和us的详细内容...

  阅读:45次