该示例有如下几个特点:
①实现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,
},
]
}
效果图如下:
该示例中的属性可在官网中查阅,若有其他疑问可私信留言互相交流学习~