let blueLegend = '' let yellowLegend = '' let historyData = [{ name:'2019.9', value:10 },{ name:'10', value:9 },{ name:'11', value:8 },{ name:'12', value:7 },{ name:'2020.1', value:6 },{ name:'2', value:5 }] let predictData = [{ name:'3', value:4 },{ name:'4', value:5 },{ name:'5', value:6 }] let data1 = historyData.map(item=>{ return [item.name,item.value] }) let data2 = predictData.map(item=>{ return [item.name,item.value] }) data2.unshift(data1[data1.length-1]) option={ backgroundColor:'#000', grid:{ right: '0', bottom: '0', left: '0', top: '48px', containLabel: true }, legend:{ data:[{ name:'实际消费金额', icon:'image://'+blueLegend },{ name:'预测值', icon:'image://'+yellowLegend }], textStyle:{ color:'rgba(134, 208, 255, 1)' }, inactiveColor:'#333', itemWidth:28, itemHeight:28, left:0 }, xAxis:{ type:'category', axisTick:{ show:false }, axisLabel:{ color:'rgba(130, 175, 198, 1)' }, axisLine:{ lineStyle:{ color:'rgba(49, 218, 255, 0.5)' } } }, yAxis:{ axisTick:{ show:false }, axisLine:{ show:false }, axisLabel:{ color:'rgba(130, 175, 198, 1)' }, splitLine:{ lineStyle:{ type:'dashed', color:'rgba(49, 218, 255, 0.5)' } } }, series:[{ name:'实际消费金额', type:'line', data:data1, itemStyle:{ normal:{ color:'rgba(49, 218, 255, 1)', shadowColor:'rgba(49, 218, 255, 1)', shadowBlur:10 } }, areaStyle:{ color:new echarts.graphic.LinearGradient(0,0,0,1,[{ offset:0, color:'rgba(49, 218, 255, 0.1)' },{ offset:1, color:'rgba(49, 218, 255, 0)' }]) } },{ name:'预测值', type:'line', data:data2, itemStyle:{ normal:{ color:'rgba(255, 236, 129, 1)' } }, lineStyle:{ type:'dashed' } }] } myChart.setOption(option)