echarts 横向柱状图示例

该示例有如下几个特点:

        ①实现tooltip自定义样式(echarts 实现tooltip提示框样式自定义-CSDN博客

        ②实现数据过多时滚动展示(echarts 数据过多时展示滚动条-CSDN博客

        ③柱状图首尾展示文字,文字内容嵌入图片

        ④柱状图终点处图片展示

代码如下:

this.options = {
  // 设置图表的位置
  grid: {
    x: 24, // 左间距
    y: 20, // 上间距
    x2: 24, // 右间距
    y2: 5, // 下间距
    containLabel: true, // grid 区域是否包含坐标轴的刻度标签, 常用于『防止标签溢出』的场景
  },
  // 提示框组件
  tooltip: {
    trigger: "axis", // 触发类型, axis: 坐标轴触发
    axisPointer: {
      // 指示器类型  'line' 直线指示器 'shadow' 阴影指示器 'none' 无指示器 'cross' 十字准星指示器。
      // 其实是种简写,表示启用两个正交的轴的 axisPointer。
      type: "none",
    },
    // 提示框浮层内容格式器,支持字符串模板和回调函数两种形式
    // 折线(区域)图、柱状(条形)图、K线图 : {a}(系列名称),{b}(类目值),{c}(数值), {d}(无)
    // formatter: "{b}: {c}件",
    className: 'custom-tooltip-box',
    formatter: function(params) {
      return `<div class='custom-tooltip-style'><span>${params[0].name}</span></br><div class="span"><span>库存数:</span><span>${params[0].value}</span></div></div>`
    },
  },
  // X轴
  xAxis: {
    type: "value", // 坐标轴类型,   'value' 数值轴,适用于连续数据
    // 坐标轴刻度
    axisTick: {
      show: false, // 是否显示坐标轴刻度 默认显示
    },
    // 坐标轴轴线
    axisLine: {
      // 是否显示坐标轴轴线 默认显示
      show: false, // 是否显示坐标轴轴线 默认显示
    },
    // 坐标轴在图表区域中的分隔线
    splitLine: {
      show: false, // 是否显示分隔线。默认数值轴显示
    },
    // 坐标轴刻度标签
    axisLabel: {
      show: false, // 是否显示刻度标签 默认显示
    },
  },
  yAxis: [
    // 左侧Y轴
    {
      type: "category", // 坐标轴类型,  'category' 类目轴,适用于离散的类目数据,为该类型时必须通过 data 设置类目数据
      // 坐标轴刻度
      axisTick: {
        show: false, // 是否显示坐标轴刻度 默认显示
      },
      // 坐标轴轴线
      axisLine: {
        // 是否显示坐标轴轴线 默认显示
        show: false, // 是否显示坐标轴轴线 默认显示
        lineStyle: {
          // 坐标轴线线的颜色
          color: "#fff",
        },
      },
      // 坐标轴在图表区域中的分隔线
      splitLine: {
        show: false, // 是否显示分隔线。默认数值轴显示
      },
      // 坐标轴刻度标签
      axisLabel: {
        show: true, // 是否显示刻度标签 默认显示
        fontSize: 16, // 文字的字体大小
        color: "#ffffff", // 刻度标签文字的颜色
        // 使用字符串模板,模板变量为刻度默认标签 {value}
        formatter: function(value) {
          return `{img|}{name|${value}}`
        },
        rich: {
          img:{
            backgroundColor: {
              image: ""
            },
            width: 20,
            height: 20
          }
        },
        inside: true,
        textStyle: {
          verticalAlign: "top",
          padding: [-26, 0, 0, 0],
        },
      },
      data: this.echartData, // 类目数据,在类目轴(type: 'category')中有效
    },
    // 右侧Y轴
    {
      type: "category", // 坐标轴类型,  'category' 类目轴,适用于离散的类目数据,为该类型时必须通过 data 设置类目数据
      // 坐标轴轴线
      axisLine: {
        show: false,
      },
      // 坐标轴刻度
      axisTick: {
        show: false,
      },
      // 坐标轴刻度标签
      axisLabel: {
        show: true, // 是否显示刻度标签 默认显示
        fontSize: 18, // 文字的字体大小
        fontWeight: 600,
        color: "#ffffffcc", // 刻度标签文字的颜色
        // margin: 10, // 刻度标签与轴线之间的距离
        // 使用字符串模板,模板变量为刻度默认标签 {value}
        formatter: "{value}",
        inside: true,
        textStyle: {
          verticalAlign: "top",
          padding: [-26, 0, 0, 0],
        },
      },
      data: this.xAxisData, // 类目数据,在类目轴(type: 'category')中有效
    },
    // 右侧Y轴 图形
    {
      // 坐标轴轴线
      axisLine: {
        show: false,
      },
      // 坐标轴刻度
      axisTick: {
        show: false,
      },
      // 坐标轴刻度标签
      axisLabel: {
        show: false
      },
      data: this.xAxisData, // 类目数据,在类目轴(type: 'category')中有效
    },
  ],
  // 系列列表
  series: [
    {
      type: "bar", // 系列类型
      name: "订单转化率", // 系列名称, 用于tooltip的显示, legend 的图例筛选
      barMaxWidth: 12, // 柱条的最大宽度,不设时自适应
      showBackground: true, // 是否显示背景色
      backgroundStyle: {
        color: 'rgba(0,194,255,0.2)'
      },
      // 图形上的文本标签
      label: {
        show: false,
        // 标签的位置 left right bottom top inside,绝对的像素值 position: [10, 10],相对的百分比 position: ['50%', '50%']
        position: "inside",
      },
      // 图形样式
      itemStyle: {
        normal: {
          //颜色渐变函数 前四个参数分别表示四个位置依次为左、下、右、上
          color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [
            {
              offset: 0,
              color: "rgba(0,133,255,0)" // 0% 处的颜色
            },
            {
              offset: 1,
              color: "#0085FF" // 100% 处的颜色
            }
          ])
        },
      },
      data: this.xAxisData, // 系列中的数据内容数组
    },
    {
      type: "pictorialBar", // 系列类型
      symbol: function(value) {
        if (value) {
          return "image://"
        } else {
          return ""
        }
      }, // 标记的图形
      symbolSize: [15, 15], // 标记的大小
      symbolOffset: [10, 0], // 标记的偏移
      symbolPosition: "end", // 标记的位置
      // 图形的样式
      itemStyle: {
        normal: {
          //颜色渐变函数 前四个参数分别表示四个位置依次为左、下、右、上
          color: function(params) {
            if(params.value == 0) {
              return "rgba(255,255,255,0)"
            }
          }
        },
      },
      z: 12, // 控制图形的前后顺序。z 值小的图形会被 z 值大的图形覆盖
      data: this.xAxisData, // 系列中的数据内容数组
    },
  ],
  dataZoom: [
    {
      // 设置滚动条的隐藏与显示
      show: this.xAxisData.length > 12 ? true : false,
      // 设置滚动条类型
      type: "slider",
      // 设置背景颜色
      backgroundColor: "#fff",
      // 设置选中范围的填充颜色
      fillerColor: "#027FFF",
      // 设置边框颜色
      borderColor: "#027FFF",
      // 是否显示detail,即拖拽时候显示详细数值信息
      showDetail: false,
      // 数据窗口范围的起始数值
      startValue: this.xAxisData.length - 1,
      // 数据窗口范围的结束数值(一页显示多少条数据,从0开始)
      endValue: this.xAxisData.length - 11,
      // empty:当前数据窗口外的数据,被设置为空。
      // 即不会影响其他轴的数据范围
      filterMode: "empty",
      // 设置滚动条宽度,相对于盒子宽度
      width: 6,
      // 设置滚动条高度
      height: '100%',
      // bottom: 4,
      // 设置滚动条显示位置
      // left: 20,
      // right: 10, //右边的距离
      // 是否锁定选择区域(或叫做数据窗口)的大小
      zoomLoxk: true,
      // 控制手柄的尺寸
      // handleSize: 0,
      // dataZoom-slider组件离容器下侧的距离
      // xAxisIndex: [0],
      // 控制哪个轴,如果是number表示控制一个轴,
      // 如果是Array表示控制多个轴。此处控制第二根轴
      yAxisIndex: [0, 1],
      // start: 50,
      // end: 50,
      // zoomLock: true, //锁定区域禁止缩放(鼠标滚动会缩放,所以禁止)
      brushSelect: false, //刷选功能
      borderRadius: 3,
      showDataShadow: false, //是否显示数据阴影 默认auto
      // filterMode: "filter",
    },
    {
      // 没有下面这块的话,只能拖动滚动条,
      // 鼠标滚轮在区域内不能控制外部滚动条
      type: "inside",
      yAxisIndex: [0, 1],
      // 滚轮是否触发缩放
      zoomOnMouseWheel: false,
      // 鼠标滚轮触发滚动
      moveOnMouseMove: true,
      moveOnMouseWheel: true,
    },
  ]
}

效果图如下:

该示例中的属性可在官网中查阅,若有其他疑问可私信留言互相交流学习~

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

超级无敌小小小白

感谢老板的打赏~^v^~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值