首页 > web前端 > Vue.js > 如何在Vue3中使用vue-router?

如何在Vue3中使用vue-router?

王林
发布: 2023-05-09 23:10:16
转载
3190 人浏览过

前言

对于大多数单页应用程序而言,管理路由是一项必不可少的功能。随着新版本的Vue Router处于Alpha阶段,我们已经可以开始查看下一个版本的Vue中它是如何工作的。

Vue3中的许多更改都会稍微改变我们访问插件和库的方式,其中包括Vue Router。

一、第一步:安装vue-router

1

npm install vue-router@4.0.0-beta.13

登录后复制

二、第二步:main.js

先来对比一下vue2和vue3中main.js的区别:(第一张为vue2,第二张为vue3)

如何在Vue3中使用vue-router?

 如何在Vue3中使用vue-router?

可以明显看到,我们在vue2中常用到的Vue对象,在vue3中由于直接使用了createApp方法“消失”了,但实际上使用createApp方法创造出来的app就是一个Vue对象,在vue2中经常使用到的Vue.use(),在vue3中可以换成app.use()正常使用;在vue3的mian.js文件中,使用vue-router直接用app.use()方法把router调用了就可以了。

注:import 路由文件导出的路由名 from "对应路由文件相对路径",项目目录如下(vue2与vue3同):

如何在Vue3中使用vue-router?

三、路由文件

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

import { createRouter, createWebHashHistory } from "vue-router"

 

const routes = [

    {

        path: '/',

        component: () => import('@/pages')             

    },

    {

        path: '/test1',

        name: "test1",

        component: () => import('@/pages/test1')   

    },

    {

        path: '/test2',

        name: "test2",

        component: () => import('@/pages/test2')   

    },

]

export const router = createRouter({

  history: createWebHashHistory(),

  routes: routes

})

 

export default router

登录后复制

四、app.vue

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

<template>

  <router-view></router-view>

</template>

 

<script>

 

export default {

  name: &#39;App&#39;,

  components: {

  }

}

</script>

 

<style>

#app {

  font-family: Avenir, Helvetica, Arial, sans-serif;

  -webkit-font-smoothing: antialiased;

  -moz-osx-font-smoothing: grayscale;

  text-align: center;

  color: #2c3e50;

  margin-top: 60px;

}

</style>

登录后复制

四、使用(比如跳转)

我们在需要使用路由的地方引入useRoute 和 useRouter (相当于vue2中的 $route 和 $router)

1

2

3

4

5

6

7

8

9

<script>

import { useRoute, useRouter } from &#39;vue-router&#39;

export default {

  setup () {

    const route = useRoute()

    const router = useRouter()

    return {}

  },

}</script>

登录后复制

例:页面跳转

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

<template>

  <h2>我是test1</h2>

  <button>toTest2</button>

</template>

<script>

import { useRouter } from &#39;vue-router&#39;

export default {

  setup () {

    const router = useRouter()

    const toTest2= (() => {

      router.push("./test2")

    })

    return {

      toTest2

    }

  },

}

</script>

<style>

</style>

登录后复制

以上是如何在Vue3中使用vue-router?的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板