最近在研究一些視覺化的工具,想嘗試一些自由度較高,除了d3.js外,百度開發的ECharts 3也是另一個不錯的選擇,相對於D3.js官方文件的說明較少外,Echarts擁有蠻不錯且詳細的文檔,以及線上開發系統,且有針對不同需求大小的版本提供使用,很用心的製作,但相對於d3.js擁有很廣大的使用者社群,ECharts所使用的社群就比較小眾,且並沒有書籍在討論,或許可能是因為Echarts的寫法,其實是比較死的,但對於基本視覺化需求已經可以做得比R自由度稍微高一點(其實,目前RStdio開發的htmlwidge項目非常厲害,結合進去很多目前知名的javascript項目如d3.js,可以直接輸入html,或是使用在shiny中,把靈活度打開,要發揮很強大的效果的話,比如自己創建htmlwidge,最好開發者要有點javascript的能力!),但在處理資料結構上會花比較多時間,可能就是一種trade off吧!
相對於Echarts 2(373kb),最新版本的Echarts3所使用的js代碼大小只有172kb,對於需要在如手機端網頁顯示的效能表現會更好。圖形種類也有些許增加,但部分語法有改變,比如在關係圖部分的重力模式稍稍調整。
文檔上有教程、API說明和配置文件,也提供網上直接調整的功能。假如沒有需要太進階的功能,直接看配置文件中各種圖類的說明,大概就足夠了。
下面有官方網站提供的範例使用
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>ECharts</title> <!-- 引入 echarts.js --> <script src="echarts.min.js"></script> </head> <body> <!-- 为ECharts准备一个具备大小(宽高)的Dom --> <div id="main" style="width: 600px;height:400px;"></div> <script type="text/javascript"> // 基于准备好的dom,初始化echarts实例 var myChart = echarts.init(document.getElementById('main')); // 指定图表的配置项和数据 var option = { title: { text: 'ECharts 入门示例' }, tooltip: {}, legend: { data:['销量'] }, xAxis: { data: ["衬衫","羊毛衫","雪纺衫","裤子","高跟鞋","袜子"] }, yAxis: {}, series: [{ name: '销量', type: 'bar', data: [5, 20, 36, 10, 10, 20] }] }; // 使用刚指定的配置项和数据显示图表。 myChart.setOption(option); </script> </body> </html>
可惜wordpress網路版不能外掛javascripts包,不然可以直接在網頁呈現效果!