Files
SaaS-lib/hx-ai-intelligent/src/view/carbonEmissionManage/carbonPlanning/index.vue

72 lines
2.3 KiB
Vue
Raw Normal View History

2024-07-29 15:13:30 +08:00
<template>
<a-tabs v-model:activeKey="activeKey" @change="handleTabChange">
2024-07-30 15:19:19 +08:00
<a-tab-pane key="1" tab="全部">
2024-08-02 15:11:57 +08:00
<all ref="allRef" />
2024-07-30 15:19:19 +08:00
</a-tab-pane>
2024-07-31 15:52:08 +08:00
<a-tab-pane key="2" tab="用电量" force-render>
2024-08-02 15:11:57 +08:00
<category ref="electricRef" />
</a-tab-pane>
<a-tab-pane key="3" tab="用水量">
<category ref="useWaterRef" />
</a-tab-pane>
<a-tab-pane key="4" tab="供水量">
<category ref="provideWaterRef" />
</a-tab-pane>
<a-tab-pane key="5" tab="碳排">
<category ref="carbonEmissionsRef" />
</a-tab-pane>
<a-tab-pane key="6" tab="供热量">
<category ref="provideHotRef" />
2024-07-31 15:52:08 +08:00
</a-tab-pane>
2024-07-29 15:13:30 +08:00
</a-tabs>
</template>
<script lang="ts" setup>
import { ref } from 'vue';
2024-07-30 15:19:19 +08:00
import all from './all/index.vue';
2024-07-31 15:52:08 +08:00
import category from './category/index.vue';
2024-07-29 15:13:30 +08:00
defineOptions({
name: 'carbonPlanning', // 与页面路由name一致缓存才可生效
2024-08-02 15:11:57 +08:00
components: {
all,
category
},
2024-07-29 15:13:30 +08:00
});
const activeKey = ref('1');
2024-08-02 15:11:57 +08:00
const allRef = ref<InstanceType<typeof all> | null>(null);
const electricRef = ref<InstanceType<typeof category> | null>(null);
const useWaterRef = ref<InstanceType<typeof category> | null>(null);
const provideWaterRef = ref<InstanceType<typeof category> | null>(null);
const carbonEmissionsRef = ref<InstanceType<typeof category> | null>(null);
const provideHotRef = ref<InstanceType<typeof category> | null>(null);
2024-07-29 15:13:30 +08:00
// 切换tab页的回调
const handleTabChange = (key) => {
console.log('Tab changed:', key);
2024-08-02 15:11:57 +08:00
// 在这里可以执行需要在页面切换时执行的逻辑
if (key === '1') {
if (allRef.value) {
allRef.value.drawEcharts();
}
} else if (key === '2') {
if (electricRef.value) {
electricRef.value.getYearData(); // 调用子组件的方法
}
} else if (key === '3') {
if (useWaterRef.value) {
useWaterRef.value.getYearData();
}
}else if (key === '4') {
if (provideWaterRef.value) {
provideWaterRef.value.getYearData();
}
}else if (key === '5') {
if (carbonEmissionsRef.value) {
carbonEmissionsRef.value.getYearData();
}
}else if (key === '6') {
if (provideHotRef.value) {
provideHotRef.value.getYearData();
}
}
2024-07-29 15:13:30 +08:00
};
</script>