渐变柱状图

描述:当前是关于Echarts图表中的 柱状图 示例。
 
            

const nullData = ''

// 暂无数据配置
function setNulldata(data = [], top = 330) {
   return [
      {
         type: 'image',
         z: 666,
         invisible: data.length > 0, // 有数据就隐藏
         style: {
            image: nullData,
            width: 100,
            shadowBlur: 0,
            shadowColor: '#000',
            shadowOffsetX: '1',
            shadowOffsetY: '1',
         },
         left: 'center',
         top: top,
      },
      {
         type: 'text',
         left: 'center',
         z: 666,
         top: top + 80,
         silent: true,
         invisible: data.length > 0, // 有数据就隐藏
         style: {
            fill: '#9d9d9d',
            fontWeight: 'bold',
            text: '暂无数据',
            fontFamily: 'Microsoft YaHei',
            fontSize: '20px',
         },
      },
   ];
}
// x轴配置,若无数据时不显示
function xAxisStyle(data = []) {
   return {
      type: 'category',
      show: data.length > 0,
      axisLine: {
         lineStyle: {
            color: 'rgba(255, 255, 255, 0.4)',
         },
      },
      splitLine: {
         show: false,
         lineStyle: {
            color: 'rgba(255, 255, 255, 0.15)',
         },
      },
      axisTick: {
         show: false,
      },
      splitArea: {
         show: false,
      },
      axisLabel: {
         interval: 0,
         color: '#89BAE5',
         fontSize: 14,
      },
   };
}
// y轴配置,若无数据时不显示
function yAxisStyle(data = []) {
   return {
      type: 'value',
      show: data.length > 0,
      axisLine: {
         lineStyle: {
            color: 'rgba(255, 255, 255, 0.4)',
         },
      },
      splitLine: {
         lineStyle: {
            type: 'dashed',
            color: 'rgba(255, 255, 255, 0.1)',
         },
      },
      axisTick: {
         show: false,
      },
      axisLabel: {
         interval: 0,
         color: '#89BAE5',
         fontSize: 14,
         fontFamily: 'DINPro-Medium',
      },
      splitArea: {
         show: false,
      },
   };
}

const tooltipStyle = {
   trigger: 'axis',
   backgroundColor: 'rgba(31, 46, 59, 0.6)',
   borderColor: 'rgba(87, 134, 173, 1)',
   axisPointer: {
      type: 'shadow',
   },
   textStyle: {
      fontSize: 12,
      color: '#fff',
   },
};

const title = {
   textStyle: {
      fontSize: 16,
      fontFamily: 'PingFang SC',
      fontWeight: 400,
      color: 'rgba(255,255,255,.6)',
   },
};


const data = [
   { name: 2021, value: 280 },
   { name: 2020, value: 271 },
   { name: 2019, value: 171 },
]
option = {
   backgroundColor: 'rgba(0,0,0,0.85)',
   color: ['#12B3FE', '#28D7E6'],
   title: {
      text: '标题',
      top: 110,
      left: 30,
      ...title,
   },
   graphic: {
      elements: [...setNulldata(data)],
   },
   grid: {
      top: 160,
      left: 30,
      bottom: 150,
      right: 10,
      containLabel: true,
   },
   tooltip: {
      ...tooltipStyle,
   },
   xAxis: {
      ...xAxisStyle(data),
      data: data.map(({ name }) => name),
      axisLine: {
         lineStyle: {
            color: 'rgba(255, 255, 255, 0.9)',
         },
      },
   },
   yAxis: {
      ...yAxisStyle(data),
      splitNumber: 2,
   },
   series: [
      {
         name: '',
         type: 'bar',
         barWidth: 10,
         data: data.map(({ value }) => value),
         itemStyle: {
            color: {
               type: 'linear',
               x: 0,
               y: 0,
               x2: 0,
               y2: 1,
               colorStops: [
                  {
                     offset: 0,
                     color: '#12B3FE', // 0% 处的颜色
                  },
                  {
                     offset: 1,
                     color: 'rgba(18, 179, 254, 0)', // 100% 处的颜色
                  },
               ],
            },
         },
         label: {
            show: true,
            position: [2, -2],
            color: '#fff',
            formatter: ' ',
            width: 6,
            height: 3,
            lineHeight: 3,
            backgroundColor: '#fff',
         },
      },
   ],
}