Vue3基础(四)___Vue-Router

简介: 本文介绍了在Vue 3中如何使用`vue-router@4`进行路由管理,包括安装路由库、定义路由配置、在组件中使用`useRouter`和`useRoute`钩子函数,以及如何在组件中进行路由跳转和获取路由参数。

今天就不先着急学习语法了,先搞了一下vue3.0的路由

Vue-Router

首先,我们npm一下

npm i vue-router@4
import {
    createRouter, createWebHashHistory } from 'vue-router'

const router = createRouter({
   
    history: createWebHashHistory(),
    routes: [
        {
   
            path: "/",
            redirect: "/home"
        },
        {
   
            path: "/home",
            name: "home",
            component: () => import('../components/HelloWorld.vue')
        }, {
   
            path: "/zjq",
            component: () => import('../components/zjq.vue')
        }
    ],
})
export default router

和vue2大同小异,都是创建路由实例对象,传递一个对象,设置模式,然后传入path数组,使用路由赖加载

 component: () => import('../components/zjq.vue')

我们需要在main.js中引入,挂载

import {
    createApp } from 'vue'
import App from './App.vue'
import './index.css'
import router from './router'
let A = createApp(App)
A.use(router)
A.mount('#app')

或者
链式写法

import {
    createApp } from 'vue'
import App from './App.vue'
import './index.css'
import router from './router'
createApp(App).use(router).mount('#app')

这个时候还是不能直接写路由访问,需要在跟组件加上一行路由出口router-view

<template>
    <div id="app">
        <router-view></router-view>
    </div>
</template>

<script>
export default {
   
  name: "App"
};
</script>

这个时候我们就可以使用路由了。

useRouter、useRoute

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

useRouter:在Vue2中可以直接this.$router得到我们路由实例的方法;
useRoute:在Vue2中可以直接this.$route得到我们路由实例的属性;
用法和Vue2的用法完全一致。

import {
    useRouter, useRoute } from 'vue-router'
         const router = useRouter()
      const route = useRoute()
      console.log(router,'router');
      console.log(route,'route');

在这里插入图片描述
在这里插入图片描述
在第一个页面跳转到第二个页面

<template>
  <div>
    <button @click="goClick">跳转到第二个页面</button>
  </div>
</template>

<script>
import axios from "../assets/js/index";
import {
    useRouter, useRoute } from 'vue-router'
import {
    ref, reactive,watch } from "vue";
export default {
   
  name: "App",
  setup() {
   
      const router = useRouter()
      const route = useRoute()
    function goClick(params) {
   
      router.push('/zjq')
    }
    console.log(route.params,'route.params')
    return {
     goClick};
  }
};
</script>

第二个页面

<template >
 <div class="container">
     <button @click="backcc">返回到第一个页面</button>
 </div>
</template>
<script>
import {
    useRouter } from "vue-router";
import {
   ref} from 'vue'
export default {
   
 setup(){
   
     let router = useRouter()
     function backcc(params) {
   
         router.push({
   
             name:"home",
             params:{
   
                 name:'zjq'
             }
         })
     }
     return {
   backcc}
 }
  }
</script>
<style  scoped>
</style>

当从第二个页面回到第一个页面后,我们可以看到打印出来了带来的params参数

 console.log(route.params,'route.params')

在这里插入图片描述

每天学习一点点。

目录
相关文章
|
23天前
|
存储 JavaScript 前端开发
vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
【10月更文挑战第21天】 vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
|
20天前
|
JavaScript 前端开发 开发者
Vue 3中的Proxy
【10月更文挑战第23天】Vue 3中的`Proxy`为响应式系统带来了更强大、更灵活的功能,解决了Vue 2中响应式系统的一些局限性,同时在性能方面也有一定的提升,为开发者提供了更好的开发体验和性能保障。
47 7
|
21天前
|
前端开发 数据库
芋道框架审批流如何实现(Cloud+Vue3)
芋道框架审批流如何实现(Cloud+Vue3)
40 3
|
20天前
|
JavaScript 数据管理 Java
在 Vue 3 中使用 Proxy 实现数据双向绑定的性能如何?
【10月更文挑战第23天】Vue 3中使用Proxy实现数据双向绑定在多个方面都带来了性能的提升,从更高效的响应式追踪、更好的初始化性能、对数组操作的优化到更优的内存管理等,使得Vue 3在处理复杂的应用场景和大量数据时能够更加高效和稳定地运行。
39 1
|
20天前
|
JavaScript 开发者
在 Vue 3 中使用 Proxy 实现数据的双向绑定
【10月更文挑战第23天】Vue 3利用 `Proxy` 实现了数据的双向绑定,无论是使用内置的指令如 `v-model`,还是通过自定义事件或自定义指令,都能够方便地实现数据与视图之间的双向交互,满足不同场景下的开发需求。
42 1
|
22天前
|
前端开发 JavaScript
简记 Vue3(一)—— setup、ref、reactive、toRefs、toRef
简记 Vue3(一)—— setup、ref、reactive、toRefs、toRef
|
23天前
Vue3 项目的 setup 函数
【10月更文挑战第23天】setup` 函数是 Vue3 中非常重要的一个概念,掌握它的使用方法对于开发高效、灵活的 Vue3 组件至关重要。通过不断的实践和探索,你将能够更好地利用 `setup` 函数来构建优秀的 Vue3 项目。
|
26天前
|
JavaScript API
vue3知识点:ref函数
vue3知识点:ref函数
32 2
|
26天前
|
API
vue3知识点:reactive函数
vue3知识点:reactive函数
26 1
|
26天前
|
JavaScript 前端开发 API
vue3知识点:Vue3.0中的响应式原理和 vue2.x的响应式
vue3知识点:Vue3.0中的响应式原理和 vue2.x的响应式
24 0
下一篇
无影云桌面