网站首页 > 精选文章 正文
Vue路由配置方法详细介绍
Vue3和Vue2基本差不多,只不过需要将createRouter、createWebHistory从vue-router中引入,再进行使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
手动配置Vue-router环境
1、下载包: npm i vue-router --save或者 npm i vue-router --S 或者用cdn引入
2、创建路由的js文件(路由、子路由、重定向、开启history模式)
createRouter、createWebHistory
//路由文件
import { createRouter, createWebHistory } from 'vue-router' //将createRouter、createWebHistory引入vue
const routes = [
{
path: '/', //配置默认路由
name: 'home', //路由名
component: () => import("../views/home.vue"), //引入该路由使用的组件
},
{
path: '/a',
name: 'a',
component: () => import('../views/a.vue'),
redirect: '/a/son1',
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文件引入到main.js中
import { createApp } from '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 scoped>
h1{
width: 400px;
height: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函数内部,是取不到传参的,返回undefined
let route=useRoute()
console.log(route)
}
</script>
<style scoped>
h2{
width: 200px;
height:100px;
background-color:aliceblue;
}
</style>
结合前者代码进行验证,发现下图状况
?
当我们进行页面跳转时成功获取了传参,但不在setup函数内使用useRouter是获取不了的
- 上一篇: vue 路由守卫
- 下一篇: vue项目本地开发完成后部署到服务器后报404是什么原因呢?
猜你喜欢
- 2024-12-29 前端vue与后端Thinkphp在服务器的部署
- 2024-12-29 第03节:创建登陆页
- 2024-12-29 详解Nginx代理Vue3项目的实践与配置
- 2024-12-29 React/Vue路由全攻略:鉴权、导航守卫与拦截,让你站在技术之巅
- 2024-12-29 Vue3.2项目架构详解
- 2024-12-29 vue项目本地开发完成后部署到服务器后报404是什么原因呢?
- 2024-12-29 vue 路由守卫
- 2024-12-29 React 对比 Vue 如何做路由鉴权?
- 2024-12-29 vue3 动态组件使用技巧
- 2024-12-29 Vue3.0权限管理实现流程【实践】
- 最近发表
- 标签列表
-
- 向日葵无法连接服务器 (32)
- git.exe (33)
- vscode更新 (34)
- dev c (33)
- git ignore命令 (32)
- gitlab提交代码步骤 (37)
- java update (36)
- vue debug (34)
- vue blur (32)
- vscode导入vue项目 (33)
- vue chart (32)
- vue cms (32)
- 大雅数据库 (34)
- 技术迭代 (37)
- 同一局域网 (33)
- github拒绝连接 (33)
- vscode php插件 (32)
- vue注释快捷键 (32)
- linux ssr (33)
- 微端服务器 (35)
- 导航猫 (32)
- 获取当前时间年月日 (33)
- stp软件 (33)
- http下载文件 (33)
- linux bt下载 (33)