BarAndLineCustom copy.vue 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. <template>
  2. <div ref="chartRef" :style="{ height, width }"></div>
  3. </template>
  4. <script lang="ts">
  5. import { defineComponent, PropType, ref, Ref, reactive, watchEffect } from 'vue';
  6. import { useECharts } from '/@/hooks/web/useECharts';
  7. export default defineComponent({
  8. name: 'BarAndLine',
  9. props: {
  10. chartData: {
  11. type: Array,
  12. default: () => [],
  13. },
  14. option: {
  15. type: Object,
  16. default: () => ({}),
  17. },
  18. xAxisPropType: {
  19. type: String,
  20. required: true,
  21. },
  22. propTypeArr: {
  23. type: Array,
  24. default: () => [],
  25. required: true,
  26. },
  27. width: {
  28. type: String as PropType<string>,
  29. default: '100%',
  30. },
  31. height: {
  32. type: String as PropType<string>,
  33. default: 'calc(100vh - 78px)',
  34. },
  35. },
  36. setup(props) {
  37. const chartRef = ref<HTMLDivElement | null>(null);
  38. const { setOptions, echarts } = useECharts(chartRef as Ref<HTMLDivElement>);
  39. const option = reactive({
  40. tooltip: {
  41. trigger: 'axis',
  42. axisPointer: {
  43. type: 'shadow',
  44. label: {
  45. show: true,
  46. backgroundColor: '#333',
  47. },
  48. },
  49. },
  50. legend: {
  51. top: 10,
  52. textStyle: {
  53. color: '#ffffffee',
  54. },
  55. },
  56. xAxis: {
  57. type: 'category',
  58. data: [],
  59. },
  60. yAxis: {
  61. type: 'value',
  62. },
  63. series: [
  64. {
  65. name: 'bar',
  66. type: 'bar',
  67. data: [],
  68. },
  69. ],
  70. });
  71. watchEffect(() => {
  72. props.chartData && initCharts();
  73. });
  74. function initCharts() {
  75. if (props.option) {
  76. Object.assign(option, props.option);
  77. }
  78. //图例类型
  79. // let typeArr = Array.from(new Set(props.chartData.map((item) => item.type)));
  80. //轴数据
  81. let xAxisData = Array.from(new Set(props.chartData.map((item) => item[props.xAxisPropType])));
  82. // let xAxisData = Array.from(new Set(props.chartData.map((item) => item.name)));
  83. let seriesData = [];
  84. [...props.propTypeArr].forEach((propType: any) => {
  85. let obj = { name: propType.name, type: propType.type };
  86. if (propType['yAxisIndex']) Object.assign(obj, { yAxisIndex: propType['yAxisIndex'] });
  87. // let obj = { name: type };
  88. // let chartArr = props.chartData.filter((item) => item === propType.name);
  89. //data数据
  90. obj['data'] = props.chartData.map((item) => item[propType.filed]);
  91. // obj['type'] = chartArr[0].seriesType;
  92. seriesData.push(obj);
  93. });
  94. console.log('seriesData------------>', seriesData);
  95. option.series = seriesData;
  96. option.xAxis.data = xAxisData;
  97. setOptions(option, false);
  98. }
  99. return { chartRef };
  100. },
  101. });
  102. </script>