vue3使用vue-router的完整步骤记录


Posted in Vue.js onJune 20, 2021

前言

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

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

一、第一步:安装vue-router

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的完整步骤记录

三、路由文件

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

<template>
  <router-view></router-view>
</template>

<script>

export default {
  name: 'App',
  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)

<script>
import { useRoute, useRouter } from 'vue-router'
export default {
  setup () {
    const route = useRoute()
    const router = useRouter()
    return {}
  },
}

例:页面跳转

<template>
  <h1>我是test1</h1>
  <button @click="toTest2">toTest2</button>
</template>
<script>
import { useRouter } from 'vue-router'
export default {
  setup () {
    const router = useRouter()
    const toTest2= (() => {
      router.push("./test2")
    })
    return {
      toTest2
    }
  },
}
</script>
<style  scoped>
</style>

总结

到此这篇关于vue3使用vue-router的文章就介绍到这了,更多相关vue3使用vue-router内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Vue.js 相关文章推荐
在Vue中使用CSS3实现内容无缝滚动的示例代码
Nov 27 Vue.js
如何在vue中使用kindeditor富文本编辑器
Dec 19 Vue.js
Vue实现简易购物车页面
Dec 30 Vue.js
vue中实现点击空白区域关闭弹窗的两种方法
Dec 30 Vue.js
vue实现轮播图帧率播放
Jan 26 Vue.js
详解vite+ts快速搭建vue3项目以及介绍相关特性
Feb 25 Vue.js
Vue3.0 手写放大镜效果
Jul 25 Vue.js
vue打包时去掉所有的console.log
Apr 10 Vue.js
解决vue-router的beforeRouteUpdate不能触发
Apr 14 Vue.js
vue 把二维或多维数组转一维数组
Apr 24 Vue.js
关于vue-router-link选择样式设置
Apr 30 Vue.js
一篇文章学会Vue中间件管道
Jun 20 #Vue.js
Vue过滤器(filter)实现及应用场景详解
使用Vue3+Vant组件实现App搜索历史记录功能(示例代码)
解决Vue+SpringBoot+Shiro跨域问题
Jun 09 #Vue.js
Vue中插槽slot的使用方法与应用场景详析
vue+elementui 实现新增和修改共用一个弹框的完整代码
解决vue $http的get和post请求跨域问题
You might like
用PHP查询搜索引擎排名位置的代码
2010/01/05 PHP
PHP number_format() 函数定义和用法
2012/06/01 PHP
ThinkPHP调用common/common.php函数提示错误function undefined的解决方法
2014/08/25 PHP
分享10段PHP常用代码
2015/11/11 PHP
分享php邮件管理器源码
2016/01/06 PHP
LINUX下PHP程序实现WORD文件转化为PDF文件的方法
2016/05/13 PHP
[原创]smarty简单模板变量输出方法
2016/07/09 PHP
深入研究PHP中的preg_replace和代码执行
2018/08/15 PHP
TP5(thinkPHP框架)实现后台清除缓存功能示例
2019/05/29 PHP
JQuery上传插件Uploadify使用详解及错误处理
2010/04/27 Javascript
扩展js对象数组的OrderByAsc和OrderByDesc方法实现思路
2013/05/17 Javascript
jQuery通过点击行来删除HTML表格行的实现示例
2014/09/10 Javascript
jQuery实现的个性化返回底部与返回顶部特效代码
2015/10/30 Javascript
javascript HTML5文件上传FileReader API
2020/03/27 Javascript
基于JavaScript实现单选框下拉菜单添加文件效果
2016/06/26 Javascript
原生js实现ajax方法(超简单)
2016/09/20 Javascript
js 提取某()特殊字符串长度的实例
2017/12/06 Javascript
微信小程序实现打开内置地图功能【附源码下载】
2017/12/07 Javascript
详解Vue中的scoped及穿透方法
2019/04/18 Javascript
vue语法自动转typescript(解放双手)
2019/09/18 Javascript
微信小程序实现图片翻转效果的实例代码
2019/09/20 Javascript
vue-cli和v-charts实现可视化图表过程解析
2019/10/08 Javascript
浅析Python中的join()方法的使用
2015/05/19 Python
详解python3实现的web端json通信协议
2016/12/29 Python
Python中shape计算矩阵的方法示例
2017/04/21 Python
Python 查看文件的读写权限方法
2018/01/23 Python
python得到一个excel的全部sheet标签值方法
2018/12/10 Python
python使用suds调用webservice接口的方法
2019/01/03 Python
详解pandas删除缺失数据(pd.dropna()方法)
2019/06/25 Python
详解用pyecharts Geo实现动态数据热力图城市找不到问题解决
2019/06/26 Python
Django框架视图层URL映射与反向解析实例分析
2019/07/29 Python
关于keras.layers.Conv1D的kernel_size参数使用介绍
2020/05/22 Python
Fossil德国官网:化石手表、手袋、珠宝及配件
2019/12/07 全球购物
医大实习自我鉴定
2013/12/07 职场文书
教师学习培训邀请函
2014/02/04 职场文书
初一年级组工作总结
2015/08/12 职场文书