圖表入門--echarts篇

1. 圖表(echarts)--數(shù)據(jù)可視化

與傳統(tǒng)形式中用表格或文檔展現(xiàn)數(shù)據(jù)的方式相比匠童,可視化能將數(shù)據(jù)以更加直觀的方式展現(xiàn)出來埂材,使數(shù)據(jù)更加客觀、更具說服力汤求。

下面是最常見的一種形式:


股票市場

數(shù)據(jù)可視化并不是簡單的把數(shù)據(jù)變成圖表俏险。而是以數(shù)據(jù)為視角严拒,看待世界。換句話說竖独,數(shù)據(jù)可視化的客體是數(shù)據(jù)裤唠,但我們想要的其實是——數(shù)據(jù)視覺,以數(shù)據(jù)為工具预鬓,以可視化為手段巧骚,目的是描述真實情況,發(fā)現(xiàn)規(guī)律格二。

可視化定義:數(shù)據(jù)可視化劈彪,是關于數(shù)據(jù)視覺表現(xiàn)形式的科學技術研究。其中顶猜,這種數(shù)據(jù)的視覺表現(xiàn)形式被定義為沧奴,一種以某種概要形式抽提出來的信息,包括相應信息單位的各種屬性和變量长窄。 它是一個處于不斷演變之中的概念滔吠,其邊界在不斷地擴大。主要指的是技術上較為高級的技術方法挠日,而這些技術方法允許利用圖形疮绷、圖像處理、計算機視覺以及用戶界面嚣潜,通過表達冬骚、建模以及對立體、表面懂算、屬性以及動畫的顯示只冻,對數(shù)據(jù)加以可視化解釋。

2. echarts介紹

ECharts是由百度團隊開發(fā)的计技,可高度個性化定制的數(shù)據(jù)可視化圖表庫喜德。它的底層依賴輕量級的Canvas類庫ZRender,是一個純JavaScript的圖表庫垮媒,兼容(IE8/9/10/11舍悯,Chrome,F(xiàn)irefox涣澡,Safari等)主流瀏覽器贱呐,可以運行在PC和移動設備上。

3. 能實現(xiàn)哪些圖表

雷達圖
餅圖
柱狀圖
折線圖
k線圖

http://echarts.baidu.com/examples/

4. 在 webpack 中使用 ECharts

Webpack 是目前比較流行的模塊打包工具入桂,你可以在使用 webpack 的項目中輕松的引入和打包 ECharts

你可以使用如下命令通過 npm 安裝 ECharts:
npm install echarts --save

5. 引入 ECharts

通過 npm 上安裝的 ECharts會放在node_modules目錄下奄薇。
// 使用 require('echarts') 得到的是已經(jīng)加載了所有圖表和組件的 ECharts 包
var echarts = require('echarts');

我們可以按需引入:

var echarts = require('echarts/lib/echarts');
// 引入柱狀圖
require('echarts/lib/chart/bar');
// 引入提示框和標題組件
require('echarts/lib/component/tooltip');
require('echarts/lib/component/title');

// 基于準備好的dom,初始化echarts實例
var myChart = echarts.init(document.getElementById('main'));
// 繪制圖表
myChart.setOption({
    title: {
        text: 'ECharts 入門示例'
    },
    tooltip: {},
    xAxis: {
        data: ['襯衫', '羊毛衫', '雪紡衫', '褲子', '高跟鞋', '襪子']
    },
    yAxis: {},
    series: [{
        name: '銷量',
        type: 'bar',
        data: [5, 20, 36, 10, 10, 20]
    }]
});
5. 繪制一個簡單的圖表

在繪圖前我們需要為 ECharts 準備一個具備高寬的 DOM 容器抗愁。

<body>
    <!-- 為 ECharts 準備一個具備大心俚佟(寬高)的 DOM -->
    <div id="main" style="width: 600px;height:400px;"></div>
</body>

然后就可以通過 echarts.init方法初始化一個 echarts實例并通過 setOption方法生成一個簡單的柱狀圖呵晚。

6.組件

除了圖表外 ECharts 中,提供了很多交互組件沫屡。例如:

圖例組件legend饵隙、標題組件 title、視覺映射組件visualMap沮脖、數(shù)據(jù)區(qū)域縮放組件dataZoom金矛、時間線組件timeline等

// echarts的核心部分幾乎都在這個option配置中
// 來個例子:
var option = {
            color: ['#90ed7d','#7cb5ec'],  // 色系
            tooltip: { //提示框組件
                trigger: 'axis',
                axisPointer: {
                    type: 'shadow'
                }
            },
            legend: { // 圖例組件
                orient: 'horizontal',
                icon: "circle",
                itemWidth: 10,
                itemHeight: 10,
                data: data.legend
            },
            barGap: '0%',
            grid: { //直角坐標系網(wǎng)格
                left: '3%',
                right: '6%',
                bottom: '3%',
                containLabel: true
            },
            xAxis: { //直角坐標系 grid 中的 x 軸
                type: 'value',
                position: 'top',
                boundaryGap: [0, 0.01],
                axisLine: {
                    show: false
                },
                axisTick: {
                    show: false
                },
                minInterval: 1
            },
            yAxis: { // 直角坐標系 grid 中的 y 軸
                type: 'category',
                data: data.names,
                axisLine: {
                    lineStyle: {
                        color: '#ccd6eb',
                    }
                },
                axisTick: {
                    lineStyle: {
                        color: '#ccd6eb',
                    }
                },
                axisLabel: {
                    textStyle: {
                        color: '#000'
                    },
                    interval: data.names.length > 20 ? 1 : 0,
                    formatter: function (value) { // 對y軸上的刻度值的顯示進行處理
                        var max_num = value.match(/[^\x00-\xff]/) == null ? 8 : 4
                        if (value.length > max_num){
                            return value.substr(0,max_num-1) + '...'
                        }
                        else {
                            return value
                        }
                    },
                },
                inverse: true //數(shù)據(jù)排序反轉
            },
            series: [ //每個系列通過 type 決定自己的圖表類型
                {
                    name: '安排記錄數(shù)',
                    type: 'bar', // 圖表類型
                    data: data.plan,
                    itemStyle: {
                        normal: {
                            label: {
                                show: true,
                                formatter: (params)=>{
                                    if (params.value == 0) return ''
                                    return params.value
                                },
                                position: 'right',
                                textStyle: {
                                    color: 'black',
                                    fontSize: 10
                                }
                            },
                            shadowBlur: {
                                shadowColor: 'rgba(0, 0, 0, 0.5)',
                                shadowBlur: 20
                            }
                        }
                    }
                },
                {
                    name: '已完成記錄數(shù)',
                    type: 'bar',
                    data: data.complete,
                    itemStyle: {
                        normal: {
                            label: {
                                show: true,
                                formatter: (params)=>{
                                    if (params.value == 0) return ''
                                    return params.value
                                },
                                position: 'right',
                                textStyle: {
                                    color: 'black',
                                    fontSize: 10
                                }
                            },
                            shadowBlur: {
                                shadowColor: 'rgba(0, 0, 0, 0.5)',
                                shadowBlur: 20
                            }
                        }
                    }
                }
            ]
        };
7.事件

在 ECharts 中主要通過 on 方法添加事件處理函數(shù)
示例:

myChart.on('click', function (params) {
    console.log(params);
});

鼠標事件包括: click,dblclickmousedown勺届,mouseup驶俊,mouseovermouseout免姿,globalout饼酿,contextmenu
所有的鼠標事件包含參數(shù) params胚膊,這是一個包含點擊圖形的數(shù)據(jù)信息的對象故俐。(移動端不支持雙擊事件dblclick,自己寫方法代替)

8.echarts的vue插件 v-charts的優(yōu)缺點

正如v-charts的官方介紹:

在使用 echarts 生成圖表時紊婉,經(jīng)常需要做繁瑣的數(shù)據(jù)類型轉化药版、修改復雜的配置項,v-charts 的出現(xiàn)正是為了解決這個痛點喻犁「斩福基于 Vue2.0 和 echarts 封裝的 v-charts 圖表組件,只需要統(tǒng)一提供一種對前后端都友好的數(shù)據(jù)格式設置簡單的配置項株汉,便可輕松生成常見的圖表。

v-charts在方便地生成圖表的同時歌殃,限制了圖表的結構乔妈。對series部分尤其是data數(shù)據(jù)支持的不好,導致生成的圖表僵化氓皱,很難進行擴展路召。 app報表第一版使用了這個組件,但后來的版本不再使用它波材。

9.highcharts

特點:是個付費的工具股淡,色系看上去更協(xié)調,個人或公司內部使用倒可以廷区,個人認為highcharts看上去更舒服吧唯灵。


部分柱狀圖
其他圖表
echarts柱狀圖

其他工具:比如D3,連色盲圖都可以生成的隙轻,但功能越多一般也越復雜https://beta.observablehq.com/@mbostock/exoplanets
官網(wǎng):https://d3js.org/

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末埠帕,一起剝皮案震驚了整個濱河市垢揩,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌敛瓷,老刑警劉巖叁巨,帶你破解...
    沈念sama閱讀 216,744評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異呐籽,居然都是意外死亡锋勺,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,505評論 3 392
  • 文/潘曉璐 我一進店門狡蝶,熙熙樓的掌柜王于貴愁眉苦臉地迎上來庶橱,“玉大人,你說我怎么就攤上這事牢酵⌒” “怎么了?”我有些...
    開封第一講書人閱讀 163,105評論 0 353
  • 文/不壞的土叔 我叫張陵馍乙,是天一觀的道長布近。 經(jīng)常有香客問我,道長丝格,這世上最難降的妖魔是什么撑瞧? 我笑而不...
    開封第一講書人閱讀 58,242評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮显蝌,結果婚禮上预伺,老公的妹妹穿的比我還像新娘。我一直安慰自己曼尊,他們只是感情好酬诀,可當我...
    茶點故事閱讀 67,269評論 6 389
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著骆撇,像睡著了一般瞒御。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上神郊,一...
    開封第一講書人閱讀 51,215評論 1 299
  • 那天肴裙,我揣著相機與錄音,去河邊找鬼涌乳。 笑死蜻懦,一個胖子當著我的面吹牛,可吹牛的內容都是我干的夕晓。 我是一名探鬼主播宛乃,決...
    沈念sama閱讀 40,096評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了烤惊?” 一聲冷哼從身側響起乔煞,我...
    開封第一講書人閱讀 38,939評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎柒室,沒想到半個月后渡贾,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,354評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡雄右,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,573評論 2 333
  • 正文 我和宋清朗相戀三年空骚,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片擂仍。...
    茶點故事閱讀 39,745評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡囤屹,死狀恐怖,靈堂內的尸體忽然破棺而出逢渔,到底是詐尸還是另有隱情肋坚,我是刑警寧澤,帶...
    沈念sama閱讀 35,448評論 5 344
  • 正文 年R本政府宣布肃廓,位于F島的核電站智厌,受9級特大地震影響,放射性物質發(fā)生泄漏盲赊。R本人自食惡果不足惜铣鹏,卻給世界環(huán)境...
    茶點故事閱讀 41,048評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望哀蘑。 院中可真熱鬧诚卸,春花似錦、人聲如沸绘迁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,683評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽缀台。三九已至辫愉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間将硝,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,838評論 1 269
  • 我被黑心中介騙來泰國打工屏镊, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留依疼,地道東北人。 一個月前我還...
    沈念sama閱讀 47,776評論 2 369
  • 正文 我出身青樓而芥,卻偏偏與公主長得像律罢,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,652評論 2 354

推薦閱讀更多精彩內容

  • 數(shù)據(jù)可視化误辑,是指將相對晦澀的的數(shù)據(jù)通過可視的沧踏、交互的方式進行展示,從而形象巾钉、直觀地表達數(shù)據(jù)蘊含的信息和規(guī)律翘狱。 早期...
    我是石老板閱讀 4,221評論 0 14
  • ECharts,一個使用 JavaScript 實現(xiàn)的開源可視化庫砰苍,可以流暢的運行在 PC 和移動設備上潦匈,兼容當前...
    YOYO做設計閱讀 9,478評論 2 7
  • 前言 公司的項目中需要對數(shù)據(jù)做可視化處理,高級點的D3.js目前還沒接觸到赚导,因此選用了大眾化的Echarts, 在...
    Mr_Treasure閱讀 165,497評論 8 44
  • 基于Vue的一些資料 內容 UI組件 開發(fā)框架 實用庫 服務端 輔助工具 應用實例 Demo示例 element★...
    嘗了又嘗閱讀 1,150評論 0 1
  • 光陰流轉,空中盤旋的落葉圈暗,卷起淡淡的傷感掂为。 走在公園的小路上,陽光抑制不住心底的惆悵厂置。我以為是自己對夏...
    玄德_3dc3閱讀 784評論 4 7