echarts3.0異步數(shù)據(jù)加載之series樣式加載

問題引入

我們知道泳赋,在echarts3.0 中引入了炫酷的展示效果屿愚,但是我們發(fā)現(xiàn)控制這些炫酷樣式的代碼全部都在series或者其他標(biāo)簽里面汇跨,如果取消之后就變成了官方實例默認(rèn)的樣式务荆。給個例子:

 option = {
        tooltip : {
            trigger: 'item',
            formatter: "{a} <br/> : {c} (p9nlx1x%)"
        },
        //注意這里的color標(biāo)簽,待會兒會注釋掉對比效果
        color:['#8fc31f','#f35833','#00ccff','#ffcc00'],
        legend: {
            orient: 'vertical',
            x: 'right',
            data: ['準(zhǔn)時','遲到','請假','未到'],
            formatter:function(name){
                var oa = option.series[0].data;
                var num = oa[0].value + oa[1].value + oa[2].value + oa[3].value;
                for(var i = 0; i < option.series[0].data.length; i++){
                    if(name==oa[i].name){
                        return name + '     ' + oa[i].value + '     ' + (oa[i].value/num * 100).toFixed(2) + '%';
                    }
                }
            }
        },
        series : [
            {
                name: '簽到比例分析',
                type: 'pie',
                radius : '55%',
                center: ['40%', '50%'],
                data:[
                    {value:335, name:'準(zhǔn)時'},
                    {value:310, name:'遲到'},
                    {value:234, name:'請假'},
                    {value:135, name:'未到'}
                ],
                itemStyle: {
                    emphasis: {
                        shadowBlur: 10,
                        shadowOffsetX: 0,
                        shadowColor: 'rgba(0, 0, 0, 0.5)'
                    },
                      normal: {
                        label:{ 
                            show: true, 
                            //position:'inside',
                            formatter: '穷遂 : {c} (1x7tzdh%)' 
                        }
                    },
                    labelLine :{show:true}
                },
              
            }
        ]
    };

加載的圖形如圖所示:


添加了樣式的option

然后我們把上面的option中的color屬性注釋掉:

/**color:['#8fc31f','#f35833','#00ccff','#ffcc00'],*/

然后函匕,就變成了這樣:


默認(rèn)樣式

這個圖例就是官方默認(rèn)的顏色,很難看有木有蚪黑。那么問題來了盅惜,我們實際應(yīng)用中加載的元素是不確定的,不可能把color定死為4個顏色祠锣,可能是3個酷窥,可能是5個咽安,如果我們要想實現(xiàn)自定義顏色伴网,該怎么才能實現(xiàn)呢?不可能把它寫到數(shù)據(jù)庫中然后單獨拼接到j(luò)son串中吧妆棒,太麻煩了而且實踐性不高澡腾。

解決方案

我們只要在js中定義一個足夠大的顏色或者樣式對象數(shù)組即可,然后再遍歷json串的時候按需加載所需要的顏色或者樣式糕珊,即有幾個展示的因子就加載幾種顏色(樣式)动分。
實際來操作一下,假設(shè)我們的json串為

var json={
    "data":[
        { "value":335,  "name":"準(zhǔn)時" },
        { "value":310,  "name":"遲到" },
        { "value":234,  "name":"請假" },
        { "value":135,  "name":"未到" }
    ],
    "text":"考勤情況統(tǒng)計報表",
    "subtext":"xx公司"
}

那么我們定義一個color數(shù)組,

//根據(jù)自己的需要红选,定義多個澜公,保證每個數(shù)據(jù)都能取到即可。
var color=['#8fc31f','#f35833','#00ccff','#ffcc00','#9c6a79','#21b6b9'...],

然后喇肋,把這個color數(shù)組按元素因子的個數(shù)去取對應(yīng)數(shù)量的顏色即可坟乾。

var color=['#8fc31f','#f35833','#00ccff','#ffcc00','#9c6a79','#21b6b9'...],
//length<=color.length;
var length=json.data.length;
//分割數(shù)組 
json.color=color.slice(0,length);

再打印json數(shù)據(jù)

var json={
    "data":[
        { "value":335,  "name":"準(zhǔn)時" },
        { "value":310,  "name":"遲到" },
        { "value":234,  "name":"請假" },
        { "value":135,  "name":"未到" }
    ],
    "text":"考勤情況統(tǒng)計報表",
    "subtext":"xx公司",
    "color":["#8fc31f","#f35833","#00ccff","#ffcc00"]
}

大功告成!這就達(dá)到了我們想要的數(shù)據(jù)蝶防,然后我們把json串中的數(shù)據(jù)加載到想應(yīng)的echarts中option即可甚侣。

復(fù)雜案例

我們前面所討論的只是顏色這一要素,是最基本的原理和思想的展示间学。那么我們再來看一個比較復(fù)雜的例子殷费。涉及到series的樣例,先上圖低葫。


折線面積圖

再來看option:

option = {
   // backgroundColor: '#394056',
    title: {
        text: '請求數(shù)',
        textStyle: {
            fontWeight: 'normal',
            fontSize: 16,
            color: '#F1F1F3'
        },
        left: '6%'
    },
    tooltip: {
        trigger: 'axis',
        axisPointer: {
            lineStyle: {
                color: '#57617B'
            }
        }
    },
    legend: {
        icon: 'rect',
        itemWidth: 14,
        itemHeight: 5,
        itemGap: 13,
        data: ['移動', '電信', '聯(lián)通'],
        right: '4%',
        textStyle: {
            fontSize: 12,
            //color: '#F1F1F3'
        }
    },
    grid: {
        left: '3%',
        right: '4%',
        bottom: '3%',
        containLabel: true
    },
    xAxis: [{
        type: 'category',
        boundaryGap: false,
        axisLine: {
            lineStyle: {
                color: '#57617B'
            }
        },
        data: ['13:00', '13:05', '13:10', '13:15', '13:20', '13:25', '13:30', '13:35', '13:40', '13:45', '13:50', '13:55']
    }, {
        axisPointer: {
            show: false
        },
        axisLine: {
            lineStyle: {
                color: '#57617B'
            }
        },
        axisTick: {
            show: false
        },

        position: 'bottom',
        offset: 20,
        data: ['', '', '', '', '', '', '', '', '', '', {
            value: '周六',
            textStyle: {
                align: 'left'
            }
        }, '周日']
    }],
    yAxis: [{
        type: 'value',
        name: '單位(%)',
        axisTick: {
            show: false
        },
        axisLine: {
            lineStyle: {
                color: '#57617B'
            }
        },
        axisLabel: {
            margin: 10,
            textStyle: {
                fontSize: 14
            }
        },
        splitLine: {
            lineStyle: {
                color: '#57617B'
            }
        }
    }],
    series: [{
        name: '移動',
        type: 'line',
        smooth: true,
        symbol: 'circle',
        symbolSize: 5,
        showSymbol: false,
        lineStyle: {
            normal: {
                width: 1
            }
        },
        //控制線條下面區(qū)域面積的顏色
        areaStyle: {
            normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                    offset: 0,
                    color: 'rgba(137, 189, 27, 0.3)'
                }, {
                    offset: 0.8,
                    color: 'rgba(137, 189, 27, 0)'
                }], false),
                shadowColor: 'rgba(0, 0, 0, 0.1)',
                shadowBlur: 10
            }
        },
        //控制線條的顏色
        itemStyle: {
            normal: {
                color: 'rgb(137,189,27)',
                borderColor: 'rgba(137,189,2,0.27)',
                borderWidth: 12

            }
        },
        data: [220, 182, 191, 134, 150, 120, 110, 125, 145, 122, 165, 122]
    }, {
        name: '電信',
        type: 'line',
        smooth: true,
        symbol: 'circle',
        symbolSize: 5,
        showSymbol: false,
        lineStyle: {
            normal: {
                width: 1
            }
        },
         //控制線條下面區(qū)域面積的顏色
        areaStyle: {
            normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                    offset: 0,
                    color: 'rgba(0, 136, 212, 0.3)'
                }, {
                    offset: 0.8,
                    color: 'rgba(0, 136, 212, 0)'
                }], false),
                shadowColor: 'rgba(0, 0, 0, 0.1)',
                shadowBlur: 10
            }
        },
        //控制線條的顏色
        itemStyle: {
            normal: {
                color: 'rgb(0,136,212)',
                borderColor: 'rgba(0,136,212,0.2)',
                borderWidth: 12

            }
        },
        data: [120, 110, 125, 145, 122, 165, 122, 220, 182, 191, 134, 150]
    }, {
        name: '聯(lián)通',
        type: 'line',
        smooth: true,
        symbol: 'circle',
        symbolSize: 5,
        showSymbol: false,
        lineStyle: {
            normal: {
                width: 1
            }
        },
        //控制線條下面區(qū)域面積的顏色
        areaStyle: {
            normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                    offset: 0,
                    color: 'rgba(219, 50, 51, 0.3)'
                }, {
                    offset: 0.8,
                    color: 'rgba(219, 50, 51, 0)'
                }], false),
                shadowColor: 'rgba(0, 0, 0, 0.1)',
                shadowBlur: 10
            }
        },
        //控制線條的顏色
        itemStyle: {
            normal: {

                color: 'rgb(219,50,51)',
                borderColor: 'rgba(219,50,51,0.2)',
                borderWidth: 12
            }
        },
        data: [220, 182, 125, 145, 122, 191, 134, 150, 120, 110, 165, 122]
    }, ]
};

好的详羡,我們把上面的注釋部分 areaStyle,itemStyle去掉,再來看效果:

默認(rèn)樣式

很明顯沒有加了樣式的好看。
這里我就說下大概思路嘿悬,和上面加載color數(shù)組顏色類似殷绍,先把需要加載的樣式areaStyle,itemStyle抽取出來做成足夠大的數(shù)組。

var areaStyle=[];
var item1={
            normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                    offset: 0,
                    color: 'rgba(0, 136, 212, 0.3)'
                }, {
                    offset: 0.8,
                    color: 'rgba(0, 136, 212, 0)'
                }], false),
                shadowColor: 'rgba(0, 0, 0, 0.1)',
                shadowBlur: 10
            }
          }
var item2={
        normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                    offset: 0,
                    color: 'rgba(0, 136, 212, 0.3)'
                }, {
                    offset: 0.8,
                    color: 'rgba(0, 136, 212, 0)'
                }], false),
                shadowColor: 'rgba(0, 0, 0, 0.1)',
                shadowBlur: 10
            }
          }
var item3=...,var item4=...
areaStyle.push(item1);
areaStyle.push(item2);   
areaStyle.push(item3); 
//itemStyle數(shù)組類似     
....
 

然后鹊漠,通過遍歷將這個2個數(shù)組添加到對應(yīng)的json串中即可,這里省略中間過程主到,最后我們得到類似這樣的json串就ok了

//這里json串沒有嚴(yán)格遵循json語法
var json={
  "data":{[220, 182, 125, 145, 122, 191, 134, 150, 120, 110, 165, 122],
            [120, 110, 125, 145, 122, 165, 122, 220, 182, 191, 134, 150].....   }
  "title":"請求數(shù)",
  "areaStyle":{
            normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                    offset: 0,
                    color: 'rgba(219, 50, 51, 0.3)'
                }, {
                    offset: 0.8,
                    color: 'rgba(219, 50, 51, 0)'
                }], false),
                shadowColor: 'rgba(0, 0, 0, 0.1)',
                shadowBlur: 10
            },
            normal:{
            ....
            },.......
        },
   "itemStyle":{
          normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                    offset: 0,
                    color: 'rgba(0, 136, 212, 0.3)'
                }, {
                    offset: 0.8,
                    color: 'rgba(0, 136, 212, 0)'
                }], false),
                shadowColor: 'rgba(0, 0, 0, 0.1)',
                shadowBlur: 10
            },
            normal:{
            .....
            },.......
          }
}

好的茶行,這樣就無所不能了,我們想要加載什么樣式都不是問題了登钥,相信大家多研究幾個例子也能觸類旁通啦畔师!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市牧牢,隨后出現(xiàn)的幾起案子看锉,更是在濱河造成了極大的恐慌,老刑警劉巖塔鳍,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件伯铣,死亡現(xiàn)場離奇詭異,居然都是意外死亡轮纫,警方通過查閱死者的電腦和手機(jī)腔寡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來掌唾,“玉大人放前,你說我怎么就攤上這事∨幢颍” “怎么了凭语?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長撩扒。 經(jīng)常有香客問我似扔,道長,這世上最難降的妖魔是什么搓谆? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任炒辉,我火速辦了婚禮,結(jié)果婚禮上挽拔,老公的妹妹穿的比我還像新娘辆脸。我一直安慰自己,他們只是感情好螃诅,可當(dāng)我...
    茶點故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布啡氢。 她就那樣靜靜地躺著,像睡著了一般术裸。 火紅的嫁衣襯著肌膚如雪倘是。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天袭艺,我揣著相機(jī)與錄音搀崭,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛瘤睹,可吹牛的內(nèi)容都是我干的升敲。 我是一名探鬼主播,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼轰传,長吁一口氣:“原來是場噩夢啊……” “哼驴党!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起获茬,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤港庄,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后恕曲,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鹏氧,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年佩谣,在試婚紗的時候發(fā)現(xiàn)自己被綠了把还。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡稿存,死狀恐怖笨篷,靈堂內(nèi)的尸體忽然破棺而出瞳秽,到底是詐尸還是另有隱情瓣履,我是刑警寧澤,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布练俐,位于F島的核電站袖迎,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏腺晾。R本人自食惡果不足惜燕锥,卻給世界環(huán)境...
    茶點故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望悯蝉。 院中可真熱鬧归形,春花似錦、人聲如沸鼻由。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蕉世。三九已至蔼紧,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間狠轻,已是汗流浹背奸例。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留向楼,地道東北人查吊。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓谐区,卻偏偏與公主長得像,于是被迫代替她去往敵國和親逻卖。 傳聞我的和親對象是個殘疾皇子卢佣,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,614評論 2 353

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,077評論 25 707
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)箭阶,斷路器虚茶,智...
    卡卡羅2017閱讀 134,652評論 18 139
  • 我的博客原文地址 AssistiveTouch iOS5+ 多任務(wù) iOS8+ 3D Touch iOS8+ iP...
    zlcode閱讀 215評論 0 1
  • 中午臨時起意,冒雨出門仇参,步行來到口口相傳專賣鐵路書籍的書屋嘹叫,門卻是鎖著的,第一個計劃沒有達(dá)成诈乒。 悻悻來到車站罩扇,沒有...
    Vivian_n閱讀 181評論 0 0
  • (10)心計 “你上回說你叫什么?” “單名一個淺字” “淺淺...從何處來的” “下界仙山提上來的” “將袖子掀...
    女少月半閱讀 837評論 0 1