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新手入门指导教程
Nov 18 Vue.js
VUE中鼠标滚轮使div左右滚动的方法详解
Dec 14 Vue.js
vue实现登录、注册、退出、跳转等功能
Dec 23 Vue.js
基于VUE实现简单的学生信息管理系统
Jan 13 Vue.js
vue项目配置 webpack-obfuscator 进行代码加密混淆的实现
Feb 26 Vue.js
Vue-router编程式导航的两种实现代码
Mar 04 Vue.js
vue3中的组件间通信
Mar 31 Vue.js
vue判断按钮是否可以点击
Apr 09 Vue.js
vue elementUI表格控制对应列
Apr 13 Vue.js
如何vue使用el-table遍历循环表头和表体数据
Apr 26 Vue.js
vue里使用create, mounted调用方法
Apr 26 Vue.js
vue postcss-px2rem 自适应布局
May 15 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
实用函数4
2007/11/08 PHP
PHP入门教程之PHP操作MySQL的方法分析
2016/09/11 PHP
PHP文件类型检查及fileinfo模块安装使用详解
2019/05/09 PHP
JavaScript实用技巧(一)
2010/08/16 Javascript
js实现特定位取反原理及示例
2014/06/30 Javascript
JavaScript函数模式详解
2014/11/07 Javascript
深入理解JavaScript系列(21):S.O.L.I.D五大原则之接口隔离原则ISP详解
2015/03/05 Javascript
无刷新上传文件并返回自定义值
2015/06/11 Javascript
JavaScript中的splice方法用法详解
2016/07/20 Javascript
javascript之with的使用(阿里云、淘宝使用代码分析)
2016/10/11 Javascript
Swiper自定义分页器使用详解
2017/12/28 Javascript
Vue EventBus自定义组件事件传递
2018/06/25 Javascript
vue 组件中添加样式不生效的解决方法
2018/07/06 Javascript
vue基于element的区间选择组件
2018/09/07 Javascript
angularJs select绑定的model取不到值的解决方法
2018/10/08 Javascript
Angular使用ControlValueAccessor创建自定义表单控件
2019/03/08 Javascript
js中console在一行内打印字符串和对象的方法
2019/09/10 Javascript
vue.js实现左边导航切换右边内容
2019/10/21 Javascript
解决vue-cli@3.xx安装不成功的问题及搭建ts-vue项目
2020/02/09 Javascript
jquery实现上传文件进度条
2020/03/26 jQuery
vue实现五子棋游戏
2020/05/28 Javascript
vue 遮罩层阻止默认滚动事件操作
2020/07/28 Javascript
Electron+vue从零开始打造一个本地播放器的方法示例
2020/10/27 Javascript
Python列表(list)、字典(dict)、字符串(string)基本操作小结
2014/11/28 Python
Python实现简单的获取图片爬虫功能示例
2017/07/12 Python
python3读取图片并灰度化图片的四种方法(OpenCV、PIL.Image、TensorFlow方法)总结
2019/07/04 Python
Pandas 缺失数据处理的实现
2019/11/04 Python
Python实现遗传算法(二进制编码)求函数最优值方式
2020/02/11 Python
草莓网美国官网:Strawberrynet USA
2016/12/11 全球购物
描述RIP和OSPF区别以及特点
2015/01/17 面试题
入股协议书范本
2014/04/14 职场文书
大学迎新标语
2014/06/26 职场文书
公司董事长助理工作职责
2014/07/12 职场文书
违反交通法规检讨书
2014/09/10 职场文书
工程部岗位职责
2015/02/10 职场文书
党小组意见范文
2015/06/08 职场文书