经过DataGear的参数化数据集、图表联动和看板API功能,能够很方便地制做支持数据钻取效果的数据可视化看板。javascript
首先,以上级地区名为参数,新建一个参数化SQL数据集:css
SELECT COL_NAME, --地区名 COL_VALUE, --地区指标数值 COL_PARENT AS COL_MAP --上级地区名,同时做为地图名 FROM T_ANALYSIS WHERE <#if 上级地区名??> COL_PARENT = '${上级地区名}' <#else> COL_PARENT = '中国' </#if>
参数:html
名称 类型 必填 上级地区名 字符串 否
T_ANALYSIS表数据示例:java
COL_NAME COL_VALUE COL_PARENT 山东 160 中国 北京 200 中国 ... 朝阳区 195 北京 海淀区 200 北京 ... 青岛市 10 山东 济南市 160 山东 ... 历下区 50 济南市 市中区 78 济南市 历城区 150 济南市 ...
而后,新建一个使用上述数据集的地图图表:git
图表类型:基本地图 数据集列标记: COL_NAME:地区名称 (name) COL_VALUE:指标数值 (value) COL_MAP:地图名 (map)
而后,新建可视化看板,填写以下看板模板内容:sql
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <style type="text/css"> .dg-chart{ display: inline-block; width: 100%; height: 480px; } </style> <script type="text/javascript"> var paramHistory = []; var chartListener = { onUpdate: function(chart, results) { //存储当前上级地区名,用于支持返回操做 var paramVal = chart.dataSetParamValue(0, 0); if(!paramVal) paramHistory = []; else paramHistory.push(paramVal); $("#title").html((paramVal ? paramVal : "全国") + " - 数据"); } }; $(document).ready(function() { $("#backButton").click(function() { //获取上一次操做的上级地区名,设置为图表参数,而后刷新图表 paramHistory.pop(); var paramVal = (paramHistory.pop() || null); var chart = dashboard.getChart("chart1"); chart.dataSetParamValue(0,0, paramVal); chart.refreshData(); }); }); </script> </head> <body class="dg-dashboard" dg-chart-map-urls="{'济南市':'jinan.json'}"> <div style="position: absolute;left:1;top:1;font-size:12px;"> DataGear <br> http://www.datagear.tech </div> <div style="font-size:2em;text-align:center;margin-bottom:5px;">DataGear 看板示例</div> <p> </p> <div style="position:relative"> <div id="title" style="text-align:center;font-size:1.2em;font-weight:bold;"></div> <button id="backButton" style="position:absolute;right:2em;top:0;">返回</button> </div> <div id="chart1" class="dg-chart" dg-chart-options="{title:{show:false}}" dg-chart-link="{target:'chart1',data:{name:0}}" dg-chart-listener="chartListener" dg-chart-disable-setting="true" dg-chart-widget="3fa7ecaf11742397c58b"> </div> </body> </html>
点击[保存并展现]按钮,打开看板展现页面,完成!!!json
注:上述示例中使用了没有内置的济南市地图JSON文件(jinan.json),须要经过看板编辑页面添加看板资源功能添加至看板。url
效果图以下所示:spa
官网地址:http://www.datagear.techcode