helongyang
2025-10-13 c5afc23437b37d717e892b16b23923907825d2cd
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
<template>
  <div class="m-charts">
    <el-tabs
      v-model="name"
      @tab-click="tabClick"
      type="border-card"
      style="height: 100%; width: 100%; box-shadow: none"
    >
      <el-tab-pane name="bar">
        <template #label>
          <span><i class="el-icon-date"></i> 柱状图 </span>
        </template>
        <div
          :style="{ height: heigth + 'px', width: width + 'px' }"
          id="bar-0001"
        ></div>
      </el-tab-pane>
      <el-tab-pane name="pie" :lazy="false" label="消息中心">
        <template #label>
          <span><i class="el-icon-date"></i> 饼状图 </span>
        </template>
        <div
          :style="{ height: heigth + 'px', width: width + 'px' }"
          id="pie-0001"
        ></div>
      </el-tab-pane>
      <el-tab-pane name="line" :lazy="false" label="角色管理">
        <template #label>
          <span><i class="el-icon-date"></i> 折线图 </span>
        </template>
        <div
          :style="{ height: heigth + 'px', width: width + 'px' }"
          id="line-0001"
        ></div>
      </el-tab-pane>
    </el-tabs>
  </div>
</template>
<script>
let echarts = require("echarts");
import options from "./chartOptions";
let $bar;
let $pie;
let $line;
export default {
  mounted() {
    $bar = echarts.init(document.getElementById("bar-0001"));
    $bar.setOption(this.options.bar);
  },
  created() {
    this.heigth = document.documentElement.clientHeight - 190;
    this.width = document.documentElement.clientWidth - 240;
  },
  methods: {
    tabClick(name) {
      if (name.props.name == "pie") {
        if (!$pie) {
          $pie = echarts.init(document.getElementById("pie-0001"));
          $pie.setOption(this.options.pie);
 
        }
      } else if (name.props.name == "line") {
        if (!$line) {
          $line = echarts.init(document.getElementById("line-0001"));
          $line.setOption(this.options.line);
         
        }
      }
    },
  },
  data() {
    return {
      name: "bar",
      heigth: 450,
      width: 1000,
      options: options,
    };
  },
};
</script>
<style lang="less" scoped>
.m-charts {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #f1f1f1;
  margin: auto 0;
  padding: 12px;
  .m-tabs {
    background: white;
  }
}
.m-charts ::v-deep(.el-tabs__content) {
  height: calc(100% - 45px);
}
.m-charts ::v-deep(.el-tab-pane) {
  height: 100%;
}
</style>