开发避坑指南(55):基于路由守卫的Vue2/Vue3 Tab页查询状态保留方案

问题

在Vue2/Vue3页面开发过程中,经常需要遇到切换tab页面后,原页面刷新,然后查询条件被清空的问题,很不友好。那么Vue2/Vue3中如何实现切换tab页面后不刷新页面,保留上一次的查询条件?

解决办法

保持组件名和路由名称一致即可。

Vue2

比如orderMng.vue中组件名称是OrderManage

export default {
	name: 'OrderManage',
	...
}

那么dynamicRoutes.js中路由地址中的也是order-manage

{
    path: 'OrderManage',
    name: 'OrderManage',
    meta: {
      name: '订单管理',
      title: '订单管理'
    },
    component: () => import('@/views/order/orderManage')
  }
Vue3

Vue3中则是在setup中指定组件的名称。

<script setup name="OrderManage">
原理

keep-alive是Vue中的一个内置组件,用于缓存不活动的组件实例,避免重复渲染DOM,从而优化性能。

组件名称和路由地址一致能实现缓存的核心机制在于的include属性通过组件名称(name)匹配缓存实例。当路由地址作为组件名称时,动态路径参数会生成唯一标识,确保不同路由实例独立缓存。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

帧栈

您的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值