解决路由缓存问题

问题

使用带有参数的路由时,相同的组件实例被重复使用。因为两个路由都渲染同个组件,比起销毁再创建,服用则更显得高效,但是这也意味着组件的生命周期的钩子不会被调用。

解决方式

为router-view添加key

html 复制代码
<router-view :key="$route.fullPath"></router-view>

onBeforeRouteUpdate

beforeRouteUpdate钩子函数可以在每次路由更新之前执行,在回调中执行需要数据更新的业务逻辑即可

javascript 复制代码
    // 保存面包屑数据
    const categoryData = ref({})
    // 面包屑数据
    // 调用getCategory方法时,若传了值,则用传的值。若没传值,则用route.params.id
    const getCategory = async (id = route.params.id) => {
        const res = await getCategoryAPI(id);
        categoryData.value = res.data.result;
        console.log(categoryData.value)
    }
    onMounted(() => getCategory())
    // 路由参数变化时,可以把分类数据接口重新发送
    onBeforeRouteUpdate((to) => {
    	// to带着参数
        getCategory(to.params.id)
    })
相关推荐
jhonjson9 分钟前
在Flutter中,禁止侧滑的方法
前端·javascript·flutter
Dragon Wu28 分钟前
前端 JS面向对象 原型 prototype
前端·javascript
看月亮的方源38 分钟前
工作笔记--css文本溢出,盒子模型,NextTick回顾、console调试、样式穿透deep全家,el-upload文件上传,.9图
前端·javascript·vue.js
没资格抱怨1 小时前
vue3中利用路由信息渲染菜单栏
前端·vue.js
TttHhhYy1 小时前
vue写后台管理系统,有个需求将所有的$message消息提示换成确认框来增强消息提示效果,遇到嵌套过多的情况,出现某些问题
前端·javascript·vue.js·anti-design-vue
计算机学姐1 小时前
基于Python的高校成绩分析管理系统
开发语言·vue.js·后端·python·mysql·pycharm·django
excel1 小时前
three Lensflare 镜头光晕
前端
FIRE1 小时前
uniapp小程序分享使用canvas自定义绘制 vue3
前端·小程序·uni-app
四喜花露水1 小时前
vue elementui el-dropdown-item设置@click无效的解决方案
前端·vue.js·elementui
jokerest1232 小时前
web——sqliabs靶场——第五关——报错注入和布尔盲注
前端