跨境派

跨境派

跨境派,专注跨境行业新闻资讯、跨境电商知识分享!

当前位置:首页 > 工具系统 > 建站工具 > Vue3路由配置createRouter、createWebHistory、useRouter,useRoute

Vue3路由配置createRouter、createWebHistory、useRouter,useRoute

时间:2024-04-22 15:25:43 来源:网络cs 作者:晨起 栏目:建站工具 阅读:

标签: 配置 

Vue3和Vue2基本差不多,只不过需要将createRoutercreateWebHistoryvue-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引入vueconst 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函数内部,是取不到传参的,返回undefinedlet route=useRoute() console.log(route)}</script> <style scoped>h2{width: 200px;    height:100px;background-color:aliceblue;}</style>

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

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

本文链接:https://www.kjpai.cn/news/2024-04-22/161262.html,文章来源:网络cs,作者:晨起,版权归作者所有,如需转载请注明来源和作者,否则将追究法律责任!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。

文章评论