echarts多个折线图共用一个x轴和tooltip组件

实现效果

根据接口传来的数据,使用echarts绘制出,共用一个x轴的图表

功能:后端将所有数据传送过来,前端通过监听选中值来展示对应的图表数据

数据格式:


代码:

vue 复制代码
<template>
  <div>
    <div class="screen-list-item">
      <span style="display: inline-block; width: 140px">量测类录波值选项:</span>
      <el-select
        multiple
        collapse-tags
        collapse-tags-tooltip
        style="width: 260px"
        clearable
        popper-class="select-box"
        :teleported="false"
        v-model="SensorListVal"
        placeholder="请输入量测"
        size="small"
        class="m-2"
      >
        <el-option
          v-for="item in SensorList.data"
          :key="item.value"
          :label="item.label"
          :value="item.value"
        />
      </el-select>
    </div>
    <div
      id="FaultRecording1"
      style="width: 800px; height: 180px; margin: auto"
    ></div>
  </div>
</template>

<script>
// 引入echarts
import * as echarts from "echarts";
import { onMounted, reactive, ref, watch } from "vue";
// 调用接口数据
import { AllRecordDataApi } from "@/utils/record";
import { RecordPostBc } from "@/utils/request";

export default {
  setup() {
    let recordDataList = ref([]);
    let xseriesdata = ref([]);
    let SensorListVal = ref([]);
    let SensorList = reactive({
      data: [],
    });
    
    // 获取录波数据
    let recordData = async () => {
      const result = await RecordPostBc(AllRecordDataApi, {});
      console.log(result)
      // 找出数据中所有选项,为筛选框的选择项
      SensorList.data = result.list.map(obj => ({ value: obj.name, label: obj.name }) );
      // 图表数据
      recordDataList.value = result.list
      xseriesdata.value = result.time
      // 默认选择前两项
      SensorListVal.value = SensorList.data.slice(0, 2).map(item => item.value);
      recordEcharts1()
    }
    
    //绘制图表
    let recordEcharts1 = () => {
      let myChart = echarts.init(document.getElementById("FaultRecording1"));
      myChart.clear(); // 清除之前的图表实例

      let options = {
        grid: [
            // 第一个折线图
            {
                left: '3%',
                right: '4%',
                top: '10%',
                height: '32%',
            },
            // 第二个折线图
            {
                left: '3%',
                right: '4%',
                top: '50%',
                height: '32%',
            },
        ],
        tooltip: {
            trigger: 'axis', 
        },
        // 将上下两个tootip合成一个
        axisPointer: {
            link: { xAxisIndex: 'all' },
        },
        xAxis: [
            {
                type: 'category',
                scale: true,
                axisLabel: {
                    show: false,
                },
                data: xseriesdata.value, //x轴时间的数据
            },
            {
                gridIndex: 1,
                type: 'category',
                scale: true,
                data: xseriesdata.value, //x轴时间的数据
            },
        ],
        yAxis: [
            {
                type: 'value',
                scale: false,
                splitLine: {
                    show: false,
                },
            },
            {
                type: 'value',
                gridIndex: 1,
                scale: true,
                splitLine: {
                    show: false,
                },
            },
        ],
        dataZoom: [
          {
            show: true,
            realtime: true,
            start: 30,
            end: 70,
            xAxisIndex: [0, 1],
          },
          {
            type: "inside",
            realtime: true,
            start: 30,
            end: 70,
            xAxisIndex: [0, 1],
          },
        ],
        series: [],
      };
      // 添加每条曲线数据到 series 中
      for (var i = 0; i < recordDataList.value.filter(record => SensorListVal.value.includes(record.name)).length; i++) {
          options.series.push({
              xAxisIndex: i,
              yAxisIndex: i,
              name: recordDataList.value.filter(record => SensorListVal.value.includes(record.name))[i].name,
              type: 'line',
              smooth: 'true',
              data: recordDataList.value.filter(record => SensorListVal.value.includes(record.name))[i].data
          });
      }
      myChart.setOption(options);
      
    }
    
    onMounted(() => {
      recordData();
    });
    
    // 监听 SensorListVal 的变化
    watch(SensorListVal, (newValue, oldValue) => {
      recordEcharts1()
    });
    
    return { SensorList, SensorListVal  };
  },
};
相关推荐
艾斯特_1 天前
Echarts常用配置项及解释
前端·javascript·echarts
winfredzhang1 天前
从零构建:基于 Node.js 与 ECharts 的量化交易策略模拟系统
前端·node.js·echarts·股票·策略
叫我辉哥e12 天前
新手进阶Python:办公看板集成多数据源+ECharts高级可视化
开发语言·python·echarts
weixin_462446232 天前
用 Python Tornado + Vue3 + ECharts 搭建 Docker 实时监控 WebSocket 仪表盘
python·echarts·tornado
叫我:松哥4 天前
基于神经网络算法的多模态内容分析系统,采用Flask + Bootstrap + ECharts + LSTM-CNN + 注意力机制
前端·神经网络·算法·机器学习·flask·bootstrap·echarts
tianxinw9 天前
uniapp x + vue3 实现echarts图表
前端·uni-app·vue·echarts
前端_Danny9 天前
用 ECharts markLine 实现节假日标注
前端·信息可视化·echarts
叫我:松哥9 天前
基于Flask+ECharts+Bootstrap构建的微博智能数据分析大屏
人工智能·python·信息可视化·数据分析·flask·bootstrap·echarts
Cherry的跨界思维12 天前
【AI测试全栈:Vue核心】22、从零到一:Vue3+ECharts构建企业级AI测试可视化仪表盘项目实战
vue.js·人工智能·echarts·vue3·ai全栈·测试全栈·ai测试全栈
该用户加载中12 天前
echarts柱状图实现斜切以及label展示
echarts