ZhangXianQiang
2024-03-01 773e59cdc3571ad0815f286bb8895a3f27a28961
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
<!-- 安全隐患情况 -->
 
<template>
  <RightTitle title="安全隐患情况">
    <template #top>
      <div class="select-container flex">
        <div class="item whitespace-no-wrap cursor-pointer" :class="{'select-active': item.isActive}" v-for="item in selectItems" :key="item.itemIndex"
          @click="changeSelect(item)">
          {{ item.name }}
        </div>
      </div>
    </template>
 
    <template #content>
      <InfoView :key="selectItems[0].itemIndex" v-show="selectItems[0].isActive"></InfoView>
      <DataView :key="selectItems[1].itemIndex" v-show="selectItems[1].isActive"></DataView>
      <!-- <TransitionGroup name="fade" mode="out-in">
        
      </TransitionGroup> -->
    </template>
 
  </RightTitle>
</template>
 
<script setup>
 
import RightTitle from "@/components/right-title";
import DataView from './dataView.vue';
import InfoView from './infoView.vue';
import { ref } from 'vue';
 
 
const selectItems = ref([
  { itemIndex: 1, name: '安全隐患', isActive: true },
  { itemIndex: 2, name: '数据统计', isActive: false },
]);
 
 
const changeSelect = (selectItem) => {
  selectItems.value.map(item => item.isActive = false);
  selectItem.isActive = true;
}
 
</script>
 
<style scoped lang="scss">
.select-container {
  flex-shrink: 0;
}
 
.item {
  margin: 0 8px;
  padding: 10px 14px;
  font-size: 12px;
  background: rgba(67, 102, 155, 0.4);
  border: 1px solid rgba(47, 91, 157, 0.8);
  flex-shrink: 0;
  color: #5B83BD;
}
 
.select-active {
 color: #fff; 
}
 
.item:last-child {
  margin-right: 0;
}
 
.fade-enter-active,
.fade-leave-active {
  transition: opacity 0.5s;
}
 
.fade-enter,
.fade-leave-to {
  opacity: 0;
  transition: opacity 0.5s;
 
}
</style>