vue-router升级后遇到的问题

前言

最近公司需要把项目从vue2升级到vue3,路由也从vue-router从3升级到4版本,这种跨版本升级,很多写法都变了,api很多也不一定兼容,所以项目的功能都要重新测一遍,有问题的就要修改。

正文

路由模式

之前vue router的路由模式是下面这种写法:

js 复制代码
import Router from 'vue-router'
new Router({
  mode: 'hash', // history,abstract等
  base: process.env.BASE_URL,  // 取自于`vue.config.js` 中的 `publicPath`字段,等同
  routes
})

通过mode字段定义路由模式,然后base字段是基准路径。

而新的vue router4则更改了写法,提供一个history字段,值有以下:

  • createWebHashHistory(base)
  • createWebHistory(base)
  • createMemoryHistory(base)

分别对应之前的hash,history,abstract模式。

然后base字段也去掉了,改成直接通过传参来代替。

js 复制代码
import { createRouter, createWebHashHistory } from 'vue-router'
const router = createRouter({
  history: createWebHashHistory(process.env.BASE_URL),
  routes
})

同时,不再采用new Router实例化,而是采用createRouter调用函数,同时还暴露出createWebHashHistory,createWebHistory等函数。

mixins的router钩子函数

以前我们的组件会在mixins里面调用router的钩子函数,比如beforeRouteUpdate钩子函数,它会在路由改变,组件复用的时候调用。

在项目中,我们会在这个beforeRouteUpdate钩子函数里更新最新的参数。

但是我们在新的vue-router4里面,发现无论参数怎么变,请求还是之前的参数,导致数据还是老数据。

排查一番,才发现是mixins的钩子函数并没有执行,导致参数不能及时更新,导致请求还是老数据。

按理说这个逻辑应该跟之前的router版本一致才对,不应该出现这样的问题。

去github一搜索,发现这个问题一直存在,到现在还没有解决。

github的issue如下:

官方的回应:

同时我们在vue-router的文档中也可以看到,在从vue2中迁移

解决方案

第一种:

我们可以在组件定义一个router钩子函数,然后里面是执行mixins对应的钩子函数,并把参数传过去,mixins那边的逻辑不用改。这样改动相对较小。

示例代码:

js 复制代码
  import mixinsjs from '@/mixins/mixinsjs'
  export default {
    mixins: [minxinjs],
    beforeRouteUpdate (to, from, next) {
        minxinjs.beforeRouteUpdate.apply(this, [to, from, next])
    }
  }

第二种:

如果你的mixins只有这些钩子函数的逻辑,而且组件上没有这些钩子,可以采用解构的方法。

js 复制代码
 import mixinsjs from '@/mixins/mixinsjs'
 export default {
    ...minxinjs, // 解构
    // rest component logic 
 }

注意: 解构的方式,组件的data和methods会覆盖掉minxins的data,和methods,请注意解构的mixins中只有钩子函数的逻辑。

第三种:

可以在mixins中,定义一个created函数 ,利用this.$route的钩子守卫函数,把mixins中的router钩子逻辑写在对应的位置。

js 复制代码
const mixinsjs =  {
  created () {
    const route = this.$route.matched[0]
    if (!route) return
    route.leaveGuards = [function (to, from, next) {
      // beforeRouteLeave 的逻辑写在这里
      next()
    }]
    route.beforeEnter = [function (to, from, next) {
      // beforeRouteEnter 的逻辑写在这里
      next()
    }]
    route.updateGuards = [function (to, from, next) {
      // beforeRouteUpdate 的逻辑写在这里
      next()
    }]
  }
}
export default mixinsjs

总结

以上就是我升级vue-router后遇到的问题,vue-router这种跨大版本的升级,肯定会存在很多兼容问题,大家先评估改动的成本,再决定是否升级。

相关推荐
Moment10 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
爱敲代码的小鱼10 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax
吹牛不交税10 小时前
admin.net-v2 框架使用笔记-netcore8.0/10.0版
vue.js·.netcore
MZ_ZXD00112 小时前
springboot旅游信息管理系统-计算机毕业设计源码21675
java·c++·vue.js·spring boot·python·django·php
铅笔侠_小龙虾12 小时前
Flutter 实战: 计算器
开发语言·javascript·flutter
大模型玩家七七13 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
2501_9447114313 小时前
JS 对象遍历全解析
开发语言·前端·javascript
发现一只大呆瓜13 小时前
虚拟列表:支持“向上加载”的历史消息(Vue 3 & React 双版本)
前端·javascript·面试
阔皮大师14 小时前
INote轻量文本编辑器
java·javascript·python·c#
lbb 小魔仙14 小时前
【HarmonyOS实战】React Native 表单实战:自定义 useReactHookForm 高性能验证
javascript·react native·react.js