您现在的位置是:亿华云 > IT科技类资讯
注意避坑,Vue Router 4: 路由参数在 Created或Setup 时不可用
亿华云2025-10-03 04:21:48【IT科技类资讯】0人已围观
简介你的可能已经注意到,VUE 3版本的 Vue router (4.0) 与其之前的版本有一些 breaking change 更改。大部分的 Vue Router API 都没有变化,而且迁移过程也非
你的注意避坑可能已经注意到,VUE 3版本的由参 Vue router (4.0) 与其之前的版本有一些 breaking change 更改。大部分的可用 Vue Router API 都没有变化,而且迁移过程也非常直接。注意避坑然而,由参一个非常不明显但重要的可用变化常常被忽视,它可能导致难以调试的注意避坑行为。现在所有的由参导航都是异步的。
如果你想知道为什么 URL中的可用查询参数在你的 setup 方法或 created 钩子中无处可寻,但当插入它们时,注意避坑它们仍然出现在模板中,由参不要离开,可用 我们来一探究竟。注意避坑
现在所有的由参导航都是异步的
为了探索这一点,我们将使用一个已经安装了Vue router 4.0 的可用Vue 3 骨架应用的 barebones 。你可以在这个 repo 中跟着代码走。
地址:https://github.com/Code-Pop/router-4-async。
项目下载下来后,亿华云计算运行 npm iinstall 然后 运行 npm run serve,界面如下所示:
如果你现在在URL中添加一些查询参数,如 <a href="http://localhost:8080/?param=1" target="blank">http://localhost:8080/?param=1</a>,页面会刷新,并将参数显示在界面上。
让我们看一下App.vue里面内容,我们在组件中添加了一个 created 的钩子。你会看到一个console.log行,它打印$router.query的内容,就像我们在模板中的那样。
Query:
{ { $route.query }}
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)
})现在,回到浏览器,添加参数并重新加载,就会在控制台上看到我们的参数信息了。
很赞哦!(759)