vue组件选项卡:实现多个组件实例数据独立
本文介绍如何使用Vue组件和选项卡组件,动态显示多个相同组件的实例,并确保每个实例的数据相互独立。
问题:开发者希望通过选项卡(例如,使用el-radio-group)切换不同的组件,且同一组件可被多次加载,每次加载都拥有独立数据。使用keep-alive和component组件后,发现多个实例共享数据,未能达到预期效果。
原因:keep-alive缓存组件实例,导致后续切换到同一组件时复用之前的实例,即使传递不同的参数,数据仍然共享。
解决方案:为每个组件实例添加唯一的key属性。
修改后的代码(app.vue):
在
<template> <div> <h1>测试</h1> <el-radio-group v-model="radio1"> <el-radio-button :key="index" :label="item.view_code" v-for="(item, index) in page_list"> {{ item.label }} </el-radio-button> </el-radio-group> <keep-alive> <component :is="radio1" :key="radio1 + '-' + (page_list.find(item => item.view_code === radio1)?.seq || 0)" :message="message"> </component> </keep-alive> </div> </template>
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实例,实现数据独立。
以上就是Vue组件选项卡下如何实现多个组件实例的数据独立?的详细内容,更多请关注知识资源分享宝库其它相关文章!
版权声明
本站内容来源于互联网搬运,
仅限用于小范围内传播学习,请在下载后24小时内删除,
如果有侵权内容、不妥之处,请第一时间联系我们删除。敬请谅解!
E-mail:dpw1001@163.com
发表评论