Vue组件选项卡:实现多个组件实例数据独立
本文介绍如何使用Vue组件和选项卡组件,动态显示多个相同组件的实例,并确保每个实例的数据相互独立。
问题:开发者希望通过选项卡(例如,使用el-radio-group
)切换不同的组件,且同一组件可被多次加载,每次加载都拥有独立数据。使用keep-alive
和component
组件后,发现多个实例共享数据,未能达到预期效果。
原因:keep-alive
缓存组件实例,导致后续切换到同一组件时复用之前的实例,即使传递不同的参数,数据仍然共享。
解决方案:为每个组件实例添加唯一的key
属性。
修改后的代码(app.vue
):
在
标签中添加key
属性,该属性值在每次创建组件实例时都必须不同。 我们可以结合item.view_code
和递增索引来确保key
的唯一性。
测试
{{ item.label }}
radio1 + '-' + (page_list.find(item => item.view_code === radio1)?.seq || 0)
确保每次切换到同一组件时,key
值都会变化,从而创建新的组件实例,避免复用缓存实例。page_list.find(...)?.seq || 0
即使find
找不到对应的seq
,也能生成有效的key
,防止key
冲突。
通过此修改,"特定测试组件A"和"特定测试组件B"将分别拥有独立的test3.vue
实例,实现数据独立。