一起来复习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,因此会导致组件被强制重新渲染。这样做的目的是为了确保在路由变化时,不复用之前的组件实例,而是创建一个新的组件实例,以确保组件能够重新加载和初始化。

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

相关推荐
bin91532 小时前
DeepSeek 助力 Vue 开发:打造丝滑的复制到剪贴板(Copy to Clipboard)
前端·javascript·vue.js·ecmascript·deepseek
晴空万里藏片云3 小时前
elment Table多级表头固定列后,合计行错位显示问题解决
前端·javascript·vue.js
曦月合一3 小时前
html中iframe标签 隐藏滚动条
前端·html·iframe
奶球不是球3 小时前
el-button按钮的loading状态设置
前端·javascript
kidding7233 小时前
前端VUE3的面试题
前端·typescript·compositionapi·fragment·teleport·suspense
Σίσυφος19005 小时前
halcon 条形码、二维码识别、opencv识别
前端·数据库
学代码的小前端5 小时前
0基础学前端-----CSS DAY13
前端·css
css趣多多6 小时前
案例自定义tabBar
前端
姑苏洛言8 小时前
DeepSeek写微信转盘小程序需求文档,这不比产品经理强?
前端
林的快手8 小时前
CSS列表属性
前端·javascript·css·ajax·firefox·html5·safari