页面内Tab切换-工程问题

组件之间的引用

导入组件

java 复制代码
import voiceComponent from '@/views/voice/voice/index.vue'

在 Vue 3 中也推荐使用 defineComponent 来明确声明一个组件。

java 复制代码
import {defineComponent} from "vue";
java 复制代码
defineComponent(() => {
  components:{
    voiceComponent
  }
})

工程需求

解决方案

```plain

<el-tabs> 是 Element Plus 提供的标签页容器组件,用于在同一个区域内切换显示不同的内容面板。

@tab-click="handleTableClick"

  • 作用:监听标签页点击事件,当用户点击标签页时触发指定的方法。
  • 解释handleTableClick 是在组件方法中定义的函数,用于处理标签页点击后的逻辑。

<el-tab-pane><el-tabs> 的子组件,用于定义每个标签页的内容 。

  • label="总的声纹样本库"
  • 作用:定义标签页的标题,会显示在标签栏上。
  • 解释label 可以是字符串或插槽内容,用于设置标签页的显示名称。
  • name="1"
  • 作用 :为每个标签页指定一个唯一标识符,用于 v-model 绑定和事件处理。
  • 解释name 必须唯一,用于控制哪个标签页被激活。

每个 <el-tab-pane> 中可以包含任意内容,包括其他组件、HTML 元素等。在你的代码中:

在这个里面导入其他的组件,这样简化了一个vue文件里面的代码,较为方便。

plain 复制代码
const handleTableClick = (tab) => {
  console.log(tab.props.name)  //对应上面的name的值
  showIndex.value = tab.props.name;
}

但是存在了一个问题,每一个页面都是很复杂的,页面无法加载,这边就进行异步加载。

使用defineAsyncComponent

plain 复制代码
import {defineAsyncComponent} from "vue";

const voiceComponent = defineAsyncComponent(() => import('@/views/voice/template/voice_raw_template.vue'));

通过v-if 来控制组件的生成,v-if为true来去生成。

plain 复制代码
<el-tab-pane label="历史生成的声纹样本" name="2">
  <div v-if="isVoiceComponentLoaded">
    <voice-component></voice-component>
  </div>
</el-tab-pane>
plain 复制代码
const isVoiceComponentLoaded = ref(false);

const handleTableClick = (tab) => {
  console.log(tab.props.name)
  showIndex.value = tab.props.name;
  if (tab.props.name == "2") {
    isVoiceComponentLoaded.value = true;
  }
}
相关推荐
斯普信专业组几秒前
Tomcat全方位监控实施方案指南
java·tomcat
忆雾屿11 分钟前
云原生时代 Kafka 深度实践:06原理剖析与源码解读
java·后端·云原生·kafka
武昌库里写JAVA24 分钟前
iview Switch Tabs TabPane 使用提示Maximum call stack size exceeded堆栈溢出
java·开发语言·spring boot·学习·课程设计
gaoliheng00633 分钟前
Redis看门狗机制
java·数据库·redis
我是唐青枫35 分钟前
.NET AOT 详解
java·服务器·.net
Su米苏1 小时前
Axios请求超时重发机制
java
本郡主是喵2 小时前
并发编程 - go版
java·服务器·开发语言
南风lof2 小时前
源码赏析:Java线程池中的那些细节
java·源码阅读
pengyu2 小时前
【Java设计原则与模式之系统化精讲:零】 | 编程世界的道与术(理论篇)
java·后端·设计模式