ExtJs整合Echarts的示例代碼
由于Echarts不提供表格功能,想要實現(xiàn)上圖下表,需要自己增加一個table標(biāo)簽。
ExtJs整合Echarts
從Echarts官網(wǎng)下載js文件通過import引用 新建一個頁面,通過豎直放置的兩個div排版,上方預(yù)留給Echarts,下方預(yù)留給table標(biāo)簽
initPanel : function() { if (this.panel) { return } var panel = new Ext.Panel({ id : 'echart', html : '<div id="mainEchart" style="height:50%;border:1px solid #ccc;padding:10px;"></div>' + '<div id="mainTable" style="position:relative;text-align:center;padding:10px;">' +'<label for="mainTable"><h1>檔案調(diào)用次數(shù)表</h1></label>' +'<table id="content-table" border="1" style="width:100%;text-align:center;">' + '<tr><th>月份</th><th>調(diào)用次數(shù)</th></tr>', buttonAlign : 'center', autoScroll : true,//允許滾動 bodyStyle : 'overflow-x:hidden; overflow-y:scroll' //開啟豎直滾動條,關(guān)閉水平滾動條 }); this.panel = panel; return this.panel; }
Echarts初始化和數(shù)據(jù)加載
官方聲明一次性只能生成一個echarts,定義相關(guān)的樣式,并且從后臺查詢數(shù)據(jù)提供給echarts
initData : function(id, personName, year) { this.id = id; var div = document.getElementById("mainEchart"); var myChart = echarts.init(div); // myChart.showLoading({ // text: "圖表數(shù)據(jù)正在努力加載..." // }); this.myChart = myChart; // 初始化數(shù)據(jù) var data = []; var yearStr = ""; var flag = false; var monthData = []; var res = QueryData();//調(diào)用數(shù)據(jù)查詢,涉及項目名,略 for (var i = 0; i < res.json.body.length; i++) { var map = res.json.body[i]; monthData.push(map.MM);//月份 data.push(map.DYCS);//調(diào)用次數(shù) } var options = { arg : { id : this.id }, noDataLoadingOption : { text : '暫無數(shù)據(jù)', effect : 'bubble', effectOption : { effect : { n : 0 } } }, title : { text : personName + "的檔案調(diào)用情況", x : 'west' }, tooltip : { trigger : 'axis' }, legend : { data : ['調(diào)用次數(shù)'] }, toolbox : { show : true, feature : { mark : { show : true }, dataView : { //重寫dataView //在切換視圖的時候能夠以<table>的形式顯示 show : true, readOnly : true, optionToContent : function(opt) { var axisData = opt.xAxis[0].data; var series = opt.series; var table = '<table style="width:100%;text-align:center" border="1"><tbody><tr>' + '<td>時間</td>' + '<td>' + series[0].name + '</td>' // + '<td>' // + series[1].name // + '</td>' + '</tr>'; for (var i = 0, l = axisData.length; i < l; i++) { table += '<tr>' + '<td>' + axisData[i] + '</td>' + '<td>' + series[0].data[i] + '</td>' // + '<td>' + series[1].data[i] // + '</td>' + '</tr>'; } table += '</tbody></table>'; return table; } }, magicType : { show : true, type : ['line', 'bar'] }, restore : { show : true }, saveAsImage : { show : true } } }, calculable : true, xAxis : [{ type : 'category', data : monthData }], yAxis : [{ type : 'value', splitArea : { show : true } }], series : [{ name : '調(diào)用次數(shù)', type : 'bar', barWidth : 35, data : data, itemStyle : {//修改柱狀圖的顏色并在頂部顯示數(shù)值 normal : { color : '#3575a8', label : { show : true, position : 'top', formatter : '{c}'//'\n{c}' } } } }] }; myChart.setOption(options, true); myChart.on('click', function eConsole(param) { }); this.tableData(personName, monthData, data) //表格的加載 }
表格數(shù)據(jù)的賦值
表格部分就是簡單的html賦值,沒什么好多講的,注意拼接完后刷新一下html即可。 代碼如下:
tableData : function(personName, monthData, data) { // 表格部分 var html = '<div id="mainTable" style="position:relative;text-align:center;padding:10px;">' +'<label for="mainTable"><h1>' + personName + '檔案調(diào)用情況表</h1></label>' +'<table id="content-table" border="1" style="width: 100%;text-align: center;">' + '<tr style="height: 30px;text-align:center;"><th>月份</th><th>調(diào)用次數(shù)</th></tr>'; // if(monthData.length != data.length) // throw new Error("數(shù)據(jù)條數(shù)不對,請檢查!"); for (var i = 0; i < data.length; i++) { html += '<tr style="height: 30px;text-align: center;">' +'<td id="data-month-'+i+'">' + monthData[i] + '</td><td id="data-value-'+i+'">' + data[i] + '</td></tr>' } html += '</table></div>'; document.getElementById('mainTable').innerHTML = html; }
以上就可完成數(shù)據(jù)的聯(lián)動,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JS中如何實現(xiàn)點擊a標(biāo)簽返回頁面頂部的問題
這篇文章主要介紹了JS中實現(xiàn)點擊a標(biāo)簽返回頁面頂部的問題,非常不錯,具有參考借鑒價值,需要的的朋友參考下吧2017-01-01Clipboard.js 無需Flash的JavaScript復(fù)制粘貼庫
這篇文章主要介紹了JavaScript 內(nèi)容復(fù)制(無需flash) Clipboard.js使用方法,需要的朋友可以參考下2015-10-10