vue3中使用keepalive和component

vue3和vue2中有些差异,直接上代码:

javascript 复制代码
  <KeepAlive include="aComponent">
          <component 
            :is='compList[active]'
            @goDetail="goDetail"
            @back="back" 
          />
      </KeepAlive>  
<script setup lang="ts">
/**
 * 将事件从报告图表中抛上来,传递具体数据
 */
import { ref ,markRaw} from 'vue'
import aComponent from './Acomponent.vue'
import bcomponent from './Bcomponent.vue'

const dataDownConfig = ref(null);
const active = ref('aComponent');
const compList = ref({
  aComponent: markRaw(aComponent ),
  bComponent: markRaw(bComponent )
})
// 通过切换active的值来切换组件
const goDetail = (data: any) => {
  active.value = 'aComponent '
}
const back = () => {
  active.value = 'bcomponent '
}
</script>      

// Acomponent.vue (给组件加名字)

javascript 复制代码
<script lang="ts" setup>
defineOptions({
  name: 'aComponent '
})
</script>
相关推荐
huangql52032 分钟前
布局单位与设计稿换算:从「看清」到「量准」
前端
牛奶1 小时前
你不知道的JS(下):深入编程
前端·javascript·电子书
牛奶1 小时前
你不知道的JS(下):深入JS(下)
前端·javascript·电子书
牛奶1 小时前
你不知道的JS(下):总结与未来
前端·javascript·电子书
牛奶1 小时前
你不知道的JS(下):深入JS(上)
前端·javascript·电子书
CappuccinoRose2 小时前
HTML语法学习文档(五)
前端·html·html5·表单
硅基动力AI3 小时前
如何判断一个关键词值不值得做?
java·前端·数据库
yq1982043011564 小时前
使用Django构建视频解析网站 从Naver视频下载器看Web开发全流程
前端·django·音视频
李明卫杭州5 小时前
在 JavaScript 中,生成器函数(Generator Function)
前端·javascript
Lethehong5 小时前
从安装到实测:基于 Claude Code + GLM-4.7 的前端生成与评测实战
前端