一起来复习Vue中路由缓存问题吧

Vue-Router 路由缓存问题及解决方案

在Vue.js项目中,使用进行页面导航时,我们常常会有一个这样的场景,点击一级分类栏中的具体某个分类,之后,会发送请求获取该分类的数据并展示到页面中,

本质是将使用<RouterLink to='' />进行跳转,并传递了分类的参数,获取到数据展示。

但是我们在实现的时候可能会遇到页面不发生跳转的现象,常常困扰着入门小白

原因

Vue-Router在渲染页面时,当遇到相同的组件时会复用该组件,这导致组件内部的数据不会再次初始化,生命周期函数也不会被再次触发。在涉及到路由传参时,就可能会引发不能请求数据的问题。

vue-router的官方文档 ,是这样介绍的: vue-router官方文档链接

解决方案

为了解决这一问题,我们可以采用以下三种方法,确保在路由参数变化时,依然能够触发数据的重新请求。

1. 使用组件内路由守卫

通过在组件内部使用路由守卫,我们可以监听路由的变化并在变化发生时触发数据请求。 to为所要跳转的路由对象,就可以获取跳转目标的url的参数。

javascript 复制代码
// 使用钩子函数 onBeforeRouteUpdate
onBeforeRouteUpdate((to) => {
    getcategoryData(to.params.id)//这里的参数按照具体情况填写
})
  1. onBeforeRouteUpdate 钩子: 这是 Vue 3 中的一个路由守卫,用于在当前路由更新时执行一些逻辑。它接受一个函数作为参数,这个函数会在路由发生变化时被调用。
  2. (to) => { getcategoryData(to.params.id) } : 这是传递给 onBeforeRouteUpdate 的回调函数。这个回调函数接收一个参数 to,代表即将跳转的路由对象。通过 to.params.id,它获取了变化后的路由参数 id
  3. getcategoryData(to.params.id) : getcategoryData 是一个用于获取和处理数据的函数,它的参数是从路由中获取的 id 参数。这个函数会在路由变化时被触发,执行相应的数据请求逻辑。

2. 使用 Watch 监听路由参数变化

借助Vue的Watch功能,我们可以实时监听路由参数的变化,一旦变化就触发相应的数据请求。

javascript 复制代码
watch(
    () => route.params.id,//这里的参数按照具体情况填写
    () => {
        getcategoryData()
    }
);
  1. watch 函数 : watch 是 Vue.js 提供的用于监听数据变化的函数。它接受两个参数,第一个参数是一个函数,返回需要被监听的数据,第二个参数是回调函数,当被监听的数据发生变化时执行。
  2. () => route.params.id : 这是第一个参数,它使用箭头函数返回 route.params.id。在 Vue Router 中,route 对象表示当前路由状态,params 是其中的一个属性,表示路由的参数。这段代码监听了 id 参数的变化。
  3. () => { getcategoryData() } : 这是第二个参数,是一个回调函数。当 route.params.id 发生变化时,就会执行这个回调函数,这个函数里通常会包含对数据的请求或处理逻辑。在这里,它调用了 getcategoryData() 函数。

3. 破坏组件复用

在路由出口标签中设置key属性,强制破坏组件复用,确保每次路由变化都能够重新渲染组件。

html 复制代码
<RouterView :key="$route.fullPath" />
  1. Vue Router : 这段代码涉及到Vue.js的路由系统,使用了<RouterView />组件。<RouterView /> 是 Vue Router 提供的用于渲染匹配到的路由组件的地方。
  2. :key="$route.fullPath" : 这里使用了Vue.js中的属性绑定,使用 :key 来绑定一个值,该值是 $route.fullPath$route 是 Vue Router 提供的一个表示当前路由状态的对象,fullPath 是其中的一个属性,表示当前完整的路由路径。
  3. 作用 : 设置了 :key="$route.fullPath" 的作用是,每当路由发生变化时,$route.fullPath 的值也会变化,由于这个值被用作组件的 key,因此会导致组件被强制重新渲染。这样做的目的是为了确保在路由变化时,不复用之前的组件实例,而是创建一个新的组件实例,以确保组件能够重新加载和初始化。

如果你觉得本文对你有帮助的话还请点个免费的赞吧,😘

相关推荐
武天18 小时前
如果使用Vue3.0实现一个 Modal,你会怎么进行设计?
vue.js
peachSoda719 小时前
封装一个不同跳转方式的通用方法(跳转外部链接,跳转其他小程序,跳转半屏小程序)
前端·javascript·微信小程序·小程序
@PHARAOH19 小时前
HOW - 浏览器兼容(含 Safari)
前端·safari
undefined在掘金3904119 小时前
flutter 仿商场_首页
前端
少卿19 小时前
react-native图标替换
前端·react native
熊猫钓鱼>_>20 小时前
TypeScript前端架构与开发技巧深度解析:从工程化到性能优化的完整实践
前端·javascript·typescript
敲敲敲敲暴你脑袋20 小时前
Canvas绘制自定义流动路径
vue.js·typescript·canvas
JYeontu20 小时前
肉眼难以分辨 UI 是否对齐,写个插件来辅助
前端·javascript
fox_20 小时前
别再踩坑!JavaScript的this关键字,一次性讲透其“变脸”真相
前端·javascript
盛夏绽放20 小时前
uni-app Vue 项目的规范目录结构全解
前端·vue.js·uni-app