天气 xAxis time类型

描述:当前是关于Echarts图表中的 折线图 示例。
 
            let icon_Map = {
   "大雪": '',
   "大雨": '',
   "多云": '',
   "雨加雪": ''
}
let zh_en = {
   "大雪": 'MajorSnow',
   "大雨": "heavyRain",
   "多云": "cloudy",
   "雨加雪": "sleet"
}
let data = [
   {
      time: '2023\11\12 09:00',
      quality: '优',
      grade: '1级',
      weather: '大雪',
      value: -8
   },
   {
      time: '2023\11\12 10:00',
      quality: '优',
      grade: '1级',
      weather: '大雨',
      value: -7
   },
   {
      time: '2023\11\12 11:00',
      quality: '优',
      grade: '1级',
      weather: '多云',
      value: -8
   },
   {
      time: '2023\11\12 12:00',
      quality: '优',
      grade: '1级',
      weather: '大雪',
      value: -8
   },
   {
      time: '2023\11\12 13:00',
      quality: '优',
      grade: '1级',
      weather: '雨加雪',
      value: -5
   },
   {
      time: '2023\11\12 14:00',
      quality: '优',
      grade: '1级',
      weather: '大雪',
      value: -5
   },
   {
      time: '2023\11\12 15:00',
      quality: '优',
      grade: '1级',
      weather: '大雪',
      value: -5
   },
   {
      time: '2023\11\12 16:00',
      quality: '优',
      grade: '1级',
      weather: '大雪',
      value: -8
   },
   {
      time: '2023\11\12 17:00',
      quality: '优',
      grade: '1级',
      weather: '多云',
      value: 1
   },
   {
      time: '2023\11\12 18:00',
      quality: '优',
      grade: '1级',
      weather: '多云',
      value: -1
   },
   {
      time: '2023\11\12 19:01',
      quality: '优',
      grade: '1级',
      weather: '多云',
      value: -5
   },

]
let maxArr = [];
maxArr.length = data.length;
maxArr.fill(1);
console.log(maxArr)
let rich_weathers = {};
let rich_img_w = 39;
for (let k in icon_Map) {
   let rich_key = zh_en[k]
   rich_weathers[rich_key] = {
      width: rich_img_w,
      height: 32,
      backgroundColor: {
         image: icon_Map[k],
      },
   }
}

let lineSymbol = ``;
let xdata = [1, 2, 3]
option = {
   backgroundColor: '#5d87bb',
   grid: [
      {
         containLabel: true,
         left: '5%',
         top: '10%',
         right: '5%',
         backgroundColor: '#5d87bb',
      },
      {
         containLabel: true,
         left: '3%',
         top: '10%',
         right: '3%',
         backgroundColor: '#5d87bb',
      }
   ],
   title: {
      text: '鼠标按下拖拽试试'
   },
   dataZoom: [
      {
         show: false, // 为true 滚动条出现
         realtime: true,
         type: 'slider', // 有type这个属性,滚动条在最下面,也可以不行,写y:36,这表示距离顶端36px,一般就是在图上面。
         right: "3%",
         left: "3%",
         height: '10',
         xAxisIndex: [0],     //关联多个y轴
         moveHandleStyle: {
            color: "rgba(89, 202, 241,.5)",
         },
         moveHandleSize: "6",
         emphasis: {
            moveHandleStyle: {
               color: "rgba(89, 202, 241,.5)",
            }
         },
         textStyle: {
            color: "rgba(255,255,255,0)",
         },
         backgroundColor: 'rgba(255,255,255,.1)',
         borderColor: "rgba(255,255,255,0)",
         fillerColor: "rgba(0,0,0,0)",
         handleSize: "6",
         handleStyle: {
            color: "rgba(255,255,255,0)"
         },
         brushStyle: {
            color: "rgba(129, 243, 253)"
         },
         start: 0,
         end: 80,
      },
      {
         type: 'inside',
         xAxisIndex: [0],     //关联多个y轴
         zoomOnMouseWheel: false,  //滚轮是否触发缩放
         moveOnMouseMove: true
      }
   ],
   xAxis: [
      {
         type: 'time',
         triggerEvent: true,
         boundaryGap: false,
         axisLabel: {
            margin: 14,
            show: true,
            formatter: (v) => {
               let newDate = new Date(v);
               let newDate_h = newDate.getHours();
               let filter_ = data.filter((o) => {
                  let _date = new Date(o.time);
                  let _date_h = _date.getHours();
                  if (_date_h == newDate_h) return o;
               })[0];
               console.log(filter_, newDate_h)
               let rich_key = zh_en[filter_.weather];

               let grade = filter_.grade;
               let quality = filter_.quality;
               let str = `{${rich_key}| }\n{text|${grade}}\n{text2|${quality}}\n{h|${newDate_h}}`
               let sh = new Date().getHours();
               if (newDate_h == sh) {
                  str = `{${rich_key}| }\n{text|${grade}}\n{text2|${quality}}\n{sh|当前}`
               }
               return str;
            },
            rich: {
               ...rich_weathers,
               text: {
                  color: "#ffffff9a",
                  height: 30,
                  lineHeight: 30,
                  fontSize: 14,
                  align: 'center',
                  padding: [1, 3, 0, 0],
                  width: rich_img_w
               },
               text2: {
                  color: "#ffffff9a",
                  height: 20,
                  fontSize: 12,
                  align: 'center',
                  width: rich_img_w,
                  borderRadius: 4,
                  padding: [1.5, 3, 0, 0],
                  backgroundColor: '#ffffff1a'
               },
               h: {
                  color: "#ffffff9a",
                  height: 26,
                  fontSize: 12,
                  align: 'center',
                  width: rich_img_w,
                  borderRadius: 4,
                  padding: [1, 3, 0, 0],
               },
               sh: {
                  color: "#ffffff",
                  height: 26,
                  fontSize: 12,
                  align: 'center',
                  width: rich_img_w,
                  borderRadius: 4,
                  padding: [1, 3, 0, 0],
               }
            }
         },
         gridIndex: 0,
         axisLine: {
            show: false,
         },
         axisTick: {
            show: false,
         },
         splitLine: {
            show: false,
         },
      },
   ],
   yAxis: [
      {
         type: 'value',
         gridIndex: 0,
         axisLabel: {
            show: false
         },
         axisLine: {
            show: false,
         },
         axisTick: {
            show: false,
         },
         splitLine: {
            show: false,
         },
      },
   ],
   color: ['#00e529'],
   series: [
      {
         type: 'line',
         symbolSize: 10,
         symbol: 'image://' + lineSymbol,
         data: data.map((v) => {
            return [
               new Date(v.time),
               v.value
            ]
         }),
         yAxisIndex: 0,
         xAxisIndex: 0,
         smooth: true,
         label: {
            show: true,
            position: 'top',
            distance: 5,
            formatter: (v) => {
               return v.value[1] + '°'
            },
            color: "#fff",
            fontSize: 18,
            fontWeight: 600
         },
      },
   ]
};