Vue Router 4: 路由参数在 created/setup 时不可用

博客探讨了Vue Router 4.0中的一个关键变化,即所有导航变为异步,这可能导致在组件创建或setup函数中无法立即访问查询参数。文章通过一个示例应用解释了这个问题,并提供了在main.js中等待路由就绪再挂载应用的解决方案,确保正确获取查询参数。同时,附带了源码下载链接和开源项目地址。
摘要由CSDN通过智能技术生成

你的可能已经注意到,VUE 3 版本的 Vue router (4.0) 与其之前的版本有一些 breaking change 更改。大部分的 Vue Router API 都没有变化,而且迁移过程也非常直接。然而,一个非常不明显但重要的变化常常被忽视,它可能导致难以调试的行为。现在所有的导航都是异步的。

如果你想知道为什么 URL 中的查询参数在你的 setup 方法或 created 钩子中无处可寻,但当插入它们时,它们仍然出现在模板中,不要离开, 我们来一探究竟。

现在所有的导航都是异步的
为了探索这一点,我们将使用一个已经安装了 Vue router 4.0 的 Vue 3 骨架应用的 barebones 。你可以在这个 repo 中跟着代码走。

地址:github.com/Code-Pop/ro…

项目下载下来后,运行 npm iinstall 然后 运行 npm run serve,界面如下所示:

在这里插入图片描述

如果你现在在 URL 中添加一些查询参数,如 http://localhost:8080/?param=1,页面会刷新,并将参数显示在界面上。

在这里插入图片描述

让我们看一下 App.vue 里面内容,我们在组件中添加了一个 created 的钩子。你会看到一个 console.log 行,它打印 $router.query 的内容,就像我们在模板中的那样。

<template>
  <div id="nav">
    <router-link to="/">Home</router-link> |
    <router-link to="/about">About</router-link>
  </div>

  <router-view/>

  Query: 
  <pre>{{ $route.query }}</pre>
</template>

<script>
export default {
  data: () => ({}),
  created () {
    console.log(this.$route.query)
  }
}
</script>

复制代码

我们继续,像刚才一样,使用和不使用查询参数再次运行这个实验。

你会注意到,无论添加多少个参数,或者重新加载多少次页面,控制台打印的 this.$route.query 都是空的。

接着,让我们来解开这个问题。

正如一开始提到的,一个经常被忽视的 Vue Router 4 的破坏性变化是,现在所有的导航都是异步的。正如文档所建议的那样,在处理 transition 时,这一点变得更加明显,因为当 Router 从空到被数据填充时,它将触发动画。

我们之所以能在浏览器中看到参数,但在控制台中却看不到,是因为 Vue 的响应式的,一旦 Router 的查询对象可用,就立即更新 HTML。记住,它现在是异步的。这个过程很快,以至于对我们来说,它似乎一直都在那里,当在 setup 函数或生命周期钩子(如 created())中处理查询参数时,这可能真的会令人困惑。

修复问题
幸运的是,这个问题的解决办法是非常简单。我们只需到 main.js 中,等待路由 ready 好后再挂载程序,如下所示:

import { createApp } from 'vue'
import App from './App.vue'
import router from './router'

const app = createApp(App)
app.use(router)

// Replace -> app.mount('#app')
router.isReady().then(() => {
    app.mount('#app')
})
复制代码

现在,回到浏览器,添加参数并重新加载,就会在控制台上看到我们的参数信息了。

源码附件已经打包好上传到百度云了,大家自行下载即可~

链接: https://pan.baidu.com/s/14G-bpVthImHD4eosZUNSFA?pwd=yu27
提取码: yu27
百度云链接不稳定,随时可能会失效,大家抓紧保存哈。

如果百度云链接失效了的话,请留言告诉我,我看到后会及时更新~

开源地址
码云地址:
http://github.crmeb.net/u/defu

Github 地址:
http://github.crmeb.net/u/defu

开源不易,Star 以表尊重,感兴趣的朋友欢迎 Star,提交 PR,一起维护开源项目,造福更多人!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CRMEB定制开发

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值