摘要:原來的格式修改為現(xiàn)在的格式篇幅所限,我這里沒有詳細列出來詳細請訪問我的的折線圖怎么分段顯示不同的顏色再次刷新,是不是兩條斷線連上了呢。
一.場景
在使用echarts3做圖表的時候,可能會遇到一些特殊的需求:
星期一到星期四這幾個點的折線顯示一個顏色,周五到周日這幾個點的折線顯示另外一個顏色,來起到強調(diào)區(qū)別的作用。
二.效果圖先看一下效果圖,你會有一個更清晰的認識:
從圖中大家可以看到,整個折線圖分了2段顏色:周一到周四的折線是紅色,周五到周日的折線是黑色。 這樣一來,是不是就有個很明顯的強調(diào)區(qū)別的作用啦。
demo下載點擊這里。
那么,怎么去實現(xiàn)這個效果呢?別著急,一步一步來,往下看。
三.echarts3的api支持嗎看到這樣的需求,第一反應(yīng)就是去api里看看有支持的函數(shù)沒。。。 在api找到半天,果然不支持。領(lǐng)導(dǎo)非要這樣做,echarts3的api里又不支持,那么怎么辦? 答案:換思路
四.思路1.折線圖的數(shù)據(jù)點在哪里被賦值的?
我們知道在echarts中圖表是通過series來實現(xiàn)的:
其中圈紅的第一個就是圖形類型為折線圖時用到的配置,折線圖的這些數(shù)據(jù)點都是通過里面的這個data數(shù)組來生成的。
2.拆分為多個series
將一個完整的折線分成兩段折線,不同的折線顯示不同的顏色即可。
我們知道周一到周日總共是7個點,series的data數(shù)據(jù)為:
series: [ { name: "指數(shù)", type: "line", data: [4, 8, 16, 32, 64, 128, 256] } ]
如果拆分成兩段折線的話,就得用兩個series,兩個series就得有兩個數(shù)據(jù)集(data數(shù)組).
其中第一個series的數(shù)據(jù)集為:
4, 8, 16, 32, 64
第二個series的數(shù)據(jù)集為:
128,256
但是在echarts中,圖形的每一個點都要有與x軸和y軸對應(yīng)的,否則,畫出來的圖形是與數(shù)據(jù)對應(yīng)不上的。
所以我們需要對上面的兩個數(shù)組進行一下改造。
3.普及一小技巧
在echarts中,若是不想讓某個點展示,則這個點對應(yīng)的data數(shù)值可以用"-"來表示。 反正這個知識點沒有在echarts3的api里提到,應(yīng)該在echarts2中繼承下來的知識點吧。
4.轉(zhuǎn)化數(shù)據(jù)集
知道上面這個小技巧后,我們就可以把這兩個數(shù)據(jù)集寫成下面這種格式了: series[0].data:
[4, 8, 16, 32, 64,"-","-"]
series[1].data:
["-","-","-","-","-",128,256]五.摞代碼
既然思路都有了,那么我們開始試試吧。
1.option的配置和主要代碼如下:
// blog: phping.sinaapp.com var dom = document.getElementById("container"); var myChart = echarts.init(dom); option = null; option = { title: { text: "echarts3的折線圖分段顯示不同的顏色", left: "center", link: "http://phping.sinaapp.com" }, tooltip: { trigger: "item", formatter: "{a}
: {c}" }, legend: { left: "left", data: ["指數(shù)"] }, xAxis: { type: "category", name: "x", splitLine: {show: false}, data: ["星期一", "星期二", "星期三", "星期四", "星期五", "星期六", "星期日"] }, grid: { left: "3%", right: "4%", bottom: "3%", containLabel: true }, yAxis: { type: "log", name: "y" }, series: [ { name: "指數(shù)", type: "line", data:[] }, { name: "指數(shù)", type: "line", data:[] } ] }; if (option && typeof option === "object") { var startTime = +new Date(); option.series[0].data = [4, 8, 16, 32, 64,"-","-"]; option.series[1].data = ["-","-","-","-",64,128,256]; myChart.setOption(option, true); }
2.走一個試試:
兩條線是分出來了,但是中間是有個斷點。如果你覺得這樣影響需求的話,則直接在series[1].data里把這個點補出來即可。
2.1原來的格式:
option.series[0].data = [4, 8, 16, 32, 64,"-","-"]; option.series[1].data = ["-","-","-","-","-",128,256];
2.2修改為現(xiàn)在的格式:
篇幅所限,我這里沒有詳細列出來.
詳細請訪問我的blog: echarts3的折線圖怎么分段顯示不同的顏色
--- ---
再次刷新,是不是兩條斷線連上了呢。效果就跟文首的demo是一樣的了。
六.總結(jié)1.遇見此類需求時,先看看api里提供了類似的方法沒有,有的話,就不用費大頭筋兒了;
2.沒有的話,就得轉(zhuǎn)變思路了,將一個折線分成多個折線。
3.巧妙利用四.3中的小知識點來繪制空點
4.實際開發(fā)中可能要比這個demo要復(fù)雜一些,但是基本思路都是一樣的。
demo下載點擊這里。歡迎大家訪問我的blog,有更精彩的文章吆!
碼字不易,轉(zhuǎn)載請注明出處。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/86313.html
摘要:原來的格式修改為現(xiàn)在的格式篇幅所限,我這里沒有詳細列出來詳細請訪問我的的折線圖怎么分段顯示不同的顏色再次刷新,是不是兩條斷線連上了呢。 一.場景 在使用echarts3做圖表的時候,可能會遇到一些特殊的需求: 星期一到星期四這幾個點的折線顯示一個顏色,周五到周日這幾個點的折線顯示另外一個顏色,來起到強調(diào)區(qū)別的作用。 二.效果圖 先看一下效果圖,你會有一個更清晰的認識: showImg(...
摘要:折線圖小技巧折線圖功能豐富且官方文檔詳細易懂,上手比較容易,這篇文章將分享一些項目中踩過的坑,示例主要以多條曲線為主,對大家完成一些曲線和的展示及交互有所幫助基本使用文檔寫得非常詳細清晰,官方示例也很豐富,中還有很多功能更強大的示例篇的是很 echarts 折線圖小技巧 echarts 折線圖功能豐富且官方文檔詳細易懂,上手比較容易,這篇文章將分享一些項目中踩過的坑,示例主要以多條曲線...
摘要:折線圖小技巧折線圖功能豐富且官方文檔詳細易懂,上手比較容易,這篇文章將分享一些項目中踩過的坑,示例主要以多條曲線為主,對大家完成一些曲線和的展示及交互有所幫助基本使用文檔寫得非常詳細清晰,官方示例也很豐富,中還有很多功能更強大的示例篇的是很 echarts 折線圖小技巧 echarts 折線圖功能豐富且官方文檔詳細易懂,上手比較容易,這篇文章將分享一些項目中踩過的坑,示例主要以多條曲線...
摘要:小結(jié)本篇主要講述了如何生成數(shù)據(jù)集以及如何對其進行可視化如何使用創(chuàng)建簡單的圖表如果使用散點圖來探索隨機漫步過程如何使用創(chuàng)建直方圖,以及如何使用直方圖來探索同時擲兩個面數(shù)不同的骰子的結(jié)果。 《Python編程:從入門到實踐》筆記。從本篇起將用三篇的篇幅介紹如何用Python進行數(shù)據(jù)可視化。 1. 前言 從本篇開始,我們將用三篇的篇幅來初步介紹如何使用Python來進行數(shù)據(jù)可視化操作。本篇的...
閱讀 4038·2021-11-22 13:53
閱讀 3632·2021-11-19 11:29
閱讀 1286·2021-09-08 09:35
閱讀 3180·2020-12-03 17:26
閱讀 522·2019-08-29 16:06
閱讀 2119·2019-08-26 13:50
閱讀 1192·2019-08-23 18:32
閱讀 2164·2019-08-23 18:12