问题
使用 ref 的性能警告 代码如下
<template>
<div>
<component :is="currentTabComponent"></component>
</div>
</template>
<script setup>
import { ref,shallowRef } from "vue";
import TodoList from "./components/TodoList.vue";
import Rate from "./components/Rate.vue";
let tabs ={
TodoList,
Rate
}
let currentTabComponent = ref(TodoList)
</script>
警告
runtime-core.esm-bundler.js:6591 [Vue warn]: Vue received a Component which was made a reactive object. This can lead to unnecessary performance overhead, and should be avoided by marking the component with
markRaw
or using
shallowRef
instead of
ref
. Component that was made reactive:
译文:
runtime-core.esm-bundler.js:6591 [Vue 警告]:Vue 收到一个组件,该组件已成为响应式对象。这会导致不必要的性能开销,应该通过使用
markRaw
标记组件或使用
shallowRef
代替
ref
来避免。被响应的组件:
markRaw: 标记一个对象,使其永远不会转换为 proxy。返回对象本身。
shallowRef: 创建一个跟踪自身 .value 变化的 ref,但不会使其值也变成响应式的。
解决
我通过将对象标记为shallowRef解决了这个问题
因此,不要将组件存储在您的状态中,而是存储对它的键控引用,并针对对象进行查找
完整代码
<template>
<div>
<h1>带动画的Todolist</h1>
<button
v-for="(i,tab) in tabs"
:key="i"
:class="['tab-button', { active: currentTabComponent === tab }]"
@click="fn(tab)"
>
{{ tab }}
</button>
<component :is="currentTabComponent"></component>
</div>
</template>
<script setup>
import { ref,shallowRef } from "vue";
import TodoList from "./components/TodoList.vue";
import Rate from "./components/Rate.vue";
let tabs ={
TodoList,
Rate
}
let currentTabComponent = shallowRef(TodoList)
function fn (tab){
currentTabComponent.value = tabs[tab]
}
</script>