echarts制作grafana 面板之折线图

最近有需求需要制作grafana 来实现自己的需求,于是开始研究

实现效果如下

实现代码

javascript 复制代码
import * as echarts from 'echarts';

var chartDom = document.getElementById('main');
var myChart = echarts.init(chartDom, 'dark');
var option;

function getLast30Days() {
  let dates = [];
  let today = new Date();

  for (let i = 0; i < 30; i++) {
    let date = new Date();
    date.setDate(today.getDate() - i);
    let month = date.getMonth() + 1; // 月份是从0开始的,所以需要加1
    let day = date.getDate();
    dates.push(`${month}/${day}`);
  }

  return dates.reverse(); // 反转数组以使日期从过去到现在排列
}
option = {
  title: {
    text: '脏数据展示面板',
    subtext: '这是副标题',
    sublink: 'https://github.com/ecomfe/echarts-stat',
    left: 'center'
  },
  backgroundColor: '#181b1f',
  tooltip: {
    trigger: 'axis',
    backgroundColor: '#181b1f',
    borderWidth: 0,
    padding: 0,
    textStyle: {
      color: 'rgba(255,255,255,0.7)'
    },
    formatter: function (params) {
      // 自定义符号样式,可以使用 HTML 标签来实现
      var content = `<div style="border:1px solid rgba(255,255,255,0.2);border-radius:4px"><div style="padding: 3px 8px;border-bottom:1px solid rgba(255,255,255,0.2)">${params[0].axisValue}</div><div style="padding:3px 8px;display:flex;align-items:center"><span style="display:inline-block;width:15px;height:4px; margin-right:5px;background-color:#73bf69;border-radius:4px"></span><span>${params[0].seriesName}</span><span style="margin-left:20px">${params[0].value}</span></div></div>`;
      return content;
    },
    axisPointer: {
      type: 'cross',
      lineStyle: {
        opacity: 0.5
      },
      crossStyle: {
        opacity: 0.5
      },
      label: {
        show: false
      }
    }
  },
  legend: {
    show: true,
    itemHeight: 4,
    itemWidth: 15,
    icon: 'rect',
    data: ['脏数据'],
    bottom: 'bottom'
  },

  xAxis: {
    type: 'category',
    boundaryGap: false, //设置从坐标轴开始显示
    axisLine: {
      show: false
    },
    axisTick: {
      show: false
    },
    splitLine: {
      show: true
    },

    data: getLast30Days(),
    minorSplitLine: {
      show: true
    }
  },
  yAxis: {
    type: 'value',
    splitLine: {
      show: true,
      lineStyle: {
        join: 'miterLimit',
        miterLimit: 10
      }
    },
    //次分割线
    minorSplitLine: {
      show: false,
      lineStyle: {
        color: '#ffffff',
        opacity: 1
      }
    }
  },
  //显示渐变线条
  //   visualMap: [
  //   {
  //     show: false,
  //     type: 'continuous',
  //     seriesIndex: 0,
  //     min: 0,
  //     max: 60,
  //     inRange: {
  //           color: ['#73bf69', 'rgba(115,191,105,.4)', '#73bf69'],
  //           symbolSize: [50, 20]
  //       }
  //   },

  // ],
  series: [
    {
      data: [
        10, 20, 24, 18, 28, 30, 20, 28, 30, 24, 20, 16, 27, 20, 10, 20, 24, 18,
        28, 30, 20, 28, 30, 24, 20, 16, 27, 20, 20, 28
      ],
      name: '脏数据',
      type: 'line',
      smooth: false, //设置平滑曲线
      showSymbol: false, //设置是否显示折现顶点的图标
      lineStyle: {
        color: '#73bf69',
        width: 1
      },
      itemStyle: {
        color: '#73bf69'
      },
      areaStyle: {
        color: '#73bf69',
        opacity: 0.1
      } //填充背景
    }
  ]
};

option && myChart.setOption(option);
相关推荐
树上有只程序猿2 分钟前
后端思维之高并发处理方案
前端
庸俗今天不摸鱼37 分钟前
【万字总结】前端全方位性能优化指南(十)——自适应优化系统、遗传算法调参、Service Worker智能降级方案
前端·性能优化·webassembly
QTX1873038 分钟前
JavaScript 中的原型链与继承
开发语言·javascript·原型模式
黄毛火烧雪下44 分钟前
React Context API 用于在组件树中共享全局状态
前端·javascript·react.js
Apifox1 小时前
如何在 Apifox 中通过 CLI 运行包含云端数据库连接配置的测试场景
前端·后端·程序员
一张假钞1 小时前
Firefox默认在新标签页打开收藏栏链接
前端·firefox
高达可以过山车不行1 小时前
Firefox账号同步书签不一致(火狐浏览器书签同步不一致)
前端·firefox
m0_593758101 小时前
firefox 136.0.4版本离线安装MarkDown插件
前端·firefox
掘金一周1 小时前
金石焕新程 >> 瓜分万元现金大奖征文活动即将回归 | 掘金一周 4.3
前端·人工智能·后端
三翼鸟数字化技术团队1 小时前
Vue自定义指令最佳实践教程
前端·vue.js