项目中遇到的问题

本文介绍如何在Vue应用中处理路由参数变化时的数据更新问题。通常情况下,仅参数变化不会触发页面重新加载,文章提供了两种解决方案:一是使用beforeRouteUpdate钩子来执行数据更新操作;二是通过在<router-view>中添加key属性,利用$route.fullPath绑定来强制页面重新渲染。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当导航栏菜单跳转到相同的页面,只有参数不同时,页面不会进行刷新加载。

由于页面的复用,根据路由传递参数的不同,进行页面数据的渲染

        最开始是使用了watch来进行路由的监听,但是路由并没有发生变化,只是参数发生了改变,只会在当前页面进行刷新。

      由于 Vue 会复用相同组件,  /page?id=1跳转到 /page?id=2 这类链接跳转时, 将不在执行 created,mounted 之类的钩子, 这时候你需要在路由组件中, 添加 beforeRouteUpdate 钩子来执行相关方法拉取数据。

 onBeforeRouteUpdate( to =>{
   // console.log(to.params, to.query)
   })

也可以在<router-view>中添加key值

<router-view :key="$route.fullPath"></router-view>

在<router-view :key=‘$route.fullPath‘>中,通过绑定一个fullPath,可以识别当前页面路由的完整址,当地址发生改变(包括参数改变)则重新渲染页面(例如动态路由参数的变化),所以组件被强制不复用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值