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 $attrs &amp; inheritAttr实现button禁用效果案例
Dec 07 Vue.js
全面解析Vue中的$nextTick
Dec 24 Vue.js
vue 实现基础组件的自动化全局注册
Dec 25 Vue.js
vue-cli4.0多环境配置变量与模式详解
Dec 30 Vue.js
Vue中引入svg图标的两种方式
Jan 14 Vue.js
如何在vue中使用HTML 5 拖放API
Jan 14 Vue.js
vue3.0中使用element的完整步骤
Mar 04 Vue.js
vue前端工程的搭建
Mar 31 Vue.js
vue3中的组件间通信
Mar 31 Vue.js
vue3使用vue-router的完整步骤记录
Jun 20 Vue.js
vue判断按钮是否可以点击
Apr 09 Vue.js
VUE解决跨域问题Access to XMLHttpRequest at
May 06 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中使用sockets:从新闻组中获取文章
2006/10/09 PHP
codeigniter教程之上传视频并使用ffmpeg转flv示例
2014/02/13 PHP
thinkphp中html:list标签传递多个参数实例
2014/10/30 PHP
PHP正则匹配反斜杠'\'和美元'$'的方法
2017/02/08 PHP
PHP + plupload.js实现多图上传并显示进度条加删除实例代码
2017/03/06 PHP
javascript 面向对象编程基础 多态
2009/08/21 Javascript
js弹窗代码 可以指定弹出间隔
2010/07/03 Javascript
javascript学习之闭包分析
2010/12/02 Javascript
javascript实现带节日和农历的日历特效
2015/02/01 Javascript
JS基于面向对象实现的拖拽库实例
2015/09/24 Javascript
jQuery 1.9.1源码分析系列(十五)之动画处理
2015/12/03 Javascript
JS两种类型的表单提交方法实例分析
2016/11/28 Javascript
BootStrap Datetimepicker 汉化的实现代码
2017/02/10 Javascript
基于jQuery中ajax的相关方法汇总(必看篇)
2017/11/08 jQuery
浅谈Webpack多页应用HMR卡住问题
2019/04/24 Javascript
vue实现鼠标经过动画
2019/10/16 Javascript
vue-router之实现导航切换过渡动画效果
2019/10/31 Javascript
[45:46]2014 DOTA2国际邀请赛中国区预选赛5.21 HGT VS DT
2014/05/23 DOTA
天翼开放平台免费短信验证码接口使用实例
2013/12/18 Python
Python实现对比不同字体中的同一字符的显示效果
2015/04/23 Python
Python切换pip安装源的方法详解
2016/11/18 Python
基于python元祖与字典与集合的粗浅认识
2017/08/23 Python
Python实现连接postgresql数据库的方法分析
2017/12/27 Python
Python实现字符型图片验证码识别完整过程详解
2019/05/10 Python
新手如何发布Python项目开源包过程详解
2019/07/11 Python
python实现倒计时小工具
2019/07/29 Python
python简单实现最大似然估计&amp;scipy库的使用详解
2020/04/15 Python
通过实例解析python subprocess模块原理及用法
2020/10/10 Python
Python jieba库分词模式实例用法
2021/01/13 Python
全世界最美丽的四星和五星级酒店预订:Prestigia.com
2017/11/15 全球购物
Gloeilampgoedkoop荷兰:在线购买灯泡
2019/02/16 全球购物
师说教学反思
2014/02/07 职场文书
元旦文艺汇演主持词
2014/03/26 职场文书
五年级学生评语大全
2014/12/26 职场文书
2016参观监狱警示教育活动心得体会
2016/01/15 职场文书
如何判断pytorch是否支持GPU加速
2021/06/01 Python