使用 Javascript  编程, 组合使用 JSON 数据格式,Mapping 和回调技术, 可以产生很强的表达效果。 在实际工作中, 总会有数据汇总的需求。 比如说, 取得了多个 device 的性能数据, 现在希望能够对其中的若干字段进行不同的汇总(有的求和,有的求平均值,有的求最大值),得到所有Device 的总的性能状况。

具体怎么实现呢? 显然, 对于指定的不同字段, 需要不同的数据汇总函数, 可以使用一个 Mapping 来管理字段与数据汇总函数之间的映射关系,并采用回调方式来计算归总值; 通常返回数据都会采用对象数组的结构, javascript 对 JSON 格式的数据操作非常方便。

具体实现代码如下( 可以直接复制到 JS 控制台执行):

  

/**
* 对多个chart数据的指定字段使用指定函数进行汇总
* @param chartDataArray chart 数据数组, 结构: [[{'timestamp': 'xxx1', 'field1': 'xxx1', 'field2': 'yyy1'}], [{'timestamp': 'xxx1', 'field1': 'xxx2', 'field2': 'yyy2'}]]
* 这些 chart 的长度应该是相同的
* @param fieldFuncMapping字段与聚合函数的映射, 结构: {'field1': func1, 'field2':func2 }
* @return 单个 chart 数据, 结构 [{'timestamp': 'xxx1', 'field1': func1('xxx1', 'xxx2'), 'field2': func2('yyy1', 'yyy2')}]
*/
var summary = function(chartDataArray, fieldFuncMapping) {
var i=0, k=0;
var chartNum = (chartDataArray == null ? 0 : chartDataArray.length);
var chartLength = (chartDataArray[0] == null ? 0 : chartDataArray[0].length);
var result = [];
var dataArrayForSinglePoint = [];
var dataSummaryForSinglePoint = 0;
var dataSummaryObjForSinglePoint = {};
var singleData = 0;
var dataItem = {};
var dataItemProperty = {};
var fieldSummaryFunc = null;
if (chartNum == 0 || chartLength == 0) {
return [];
}
dataItemProperty = chartDataArray[0][0];
for (k=0; k < chartLength; k++) {
dataSummaryObjForSinglePoint = {};
for (var field in dataItemProperty) {
dataArrayForSinglePoint = [];
for (i=0; i<chartNum;i++) {
dataItem = chartDataArray[i][k];
singleData = dataItem[field];
dataArrayForSinglePoint.push(singleData);
}
fieldSummaryFunc = fieldFuncMapping[field];
if (fieldSummaryFunc == null) {
fieldSummaryFunc = obtainFirstFunc;
}
dataSummaryForSinglePoint = fieldSummaryFunc(dataArrayForSinglePoint);
dataSummaryObjForSinglePoint[field] = dataSummaryForSinglePoint;
}
result.push(dataSummaryObjForSinglePoint);
}
return result;
}
var obtainFirstFunc = function(array) {
return array[0];
}
var sumFunc = function(array) {
var i=0, sum = 0;
var len = (array == null ? 0 : array.length);
if (len == 0) { return 0; }
for(i=0; i<len; i++) {
sum += array[i];
}
return sum;
}
var averageFunc = function(array) {
var i=0, sum = 0;
var len = (array == null ? 0 : array.length);
if (len == 0) { return 0; }
sum = sumFunc(array);
return sum / len;
}
var testFunc = function() {
var chart1 = [{'time': 'time1', 'num': 13, 'grade': 95}, {'time': 'time2', 'num': 15, 'grade': 99}, {'time': 'time3', 'num': 16, 'grade': 94}];
var chart2 = [{'time': 'time1', 'num': 16, 'grade': 93}, {'time': 'time2', 'num': 14, 'grade': 95}, {'time': 'time3', 'num': 18, 'grade': 97}];
var fieldFuncMapping = {'num': sumFunc, 'grade': averageFunc};
var chart = summary([chart1, chart2], fieldFuncMapping);
console.log(chart);
}
testFunc();

附上一个 javascript 的陷阱:

javascript编程: JSON, Mapping, 回调的更多相关文章

  1. JavaScript高级编程———JSON

    JavaScript高级编程———JSON < script > /*JSON的语法可以表达一下三种类型的值 简单值:使用与javas相同的语法,可以在JSON中表达字符串.数值.布尔值和 ...

  2. 学习现代 JavaScript 编程的最佳教程

    天天编码 , 版权所有丨本文标题:0.0 学习现代 JavaScript 编程的最佳教程 转载请保留页面地址:http://www.tiantianbianma.com/the-modern-java ...

  3. Javascript编程风格

    Douglas Crockford是Javascript权威,Json格式就是他的发明. 去年11月他有一个演讲(Youtube),谈到了好的Javascript编程风格是什么.我非常推荐这个演讲,它 ...

  4. Javascript编程模式(JavaScript Programming Patterns)Part 1.(初级篇)

    JavaScript 为网站添加状态,这些状态可能是校验或者更复杂的行为像拖拽终止功能或者是异步的请求webserver (aka Ajax). 在过去的那些年里, JavaScript librar ...

  5. javascript编程思想

    javascript编程开发修炼之道   提要文摘附注: 本文的核心内容是围绕javascript前端开发的编程技术要素,来深入地探讨编写高质量的javascript代码的方法.技巧.规范和最佳实践, ...

  6. 小白科普之JavaScript的JSON

    一.对json的理解     json是一种数据格式,不是一种编程语言,json并不从属于javascript.     json的语法可以表示以下三种类型的值     1)简单值           ...

  7. JavaScript 拼接JSON

    <script language="javascript" type="text/javascript"> var json="" ...

  8. 在Javascript操作JSON对象,增加 删除 修改

    在Javascript操作JSON对象,增加删除修改全有的,详情见代码 <script type="text/javascript"> var jsonObj2 = { ...

  9. JavaScript对Json的增删改属性

    <script type="text/javascript"> var json = { "age":24, "name":&q ...

随机推荐

  1. jquery .post .get中文参数乱码解决方法详解

    jquery默认的编码为utf-8,做项目时有时处于项目需要用到ajax提交中文参数,乱码问题就很头疼了,折腾了许久终于弄出来了.为了便于传输,我们首先将需要用到的参数用javascript自带的函数 ...

  2. 通过jquery获取ul中第一个li的属性

    当加载列表时,默认希望选中第一条.top_menu 为ul的ID 通过 $("#top_menu li:first") 就可以获取到 ul下第一个li标签.然后就可以利用 例如 修 ...

  3. wamp虚拟主机的配置 .

    开发环境:WAMP 实例一,Apaceh配置localhost虚拟主机步骤 1,用记事本打开apache目录下httpd文件(如:D:\wamp\bin\apache\apache2.2.8\conf ...

  4. 演示save point及自治事务的用处

    1.确认数据库版本 2 举一个例子,说明save point的用处,给出SQL演示. 2.1环境准备 save point的作用是通过在事务中间设置检查点,可以更加精细的控制事务,防止一部分操作错误而 ...

  5. original.txt和提交的页面输出的文字的混合文件

    如果从准确的角度来说,那PHP文档是最准确的,因为它很简练的列出了实现文本类文件触发下载所需要的三条语句,以PDF为例就是: 代码如下:// We'll be outputting a PDF hea ...

  6. ubuntu apt-get install php

    sudo add-apt-repository ppa:ondrej/php apt-get upgrade apt-get update

  7. XE5 ImageList的BUG?

    今天做界面, 在imagelist里加载一个带有半透明通道的PNG图, 结果发现图片居然发暗, 如下: 原图: IDE里加载以后的图: 明显变暗...查询了源码, 无果 然后又用2010去测试, 发现 ...

  8. mvc3升级mvc4的方法记录.

    手工升级ASP.NET MVC 3项目: 一.安装ASP.NET MVC 4 二.升级ASP.NET MVC版本配置信息: 1:替换项目 Web.config 中的 System.Web.Mvc, V ...

  9. 《Linux内核设计与实现》CHAPTER1,2阅读梳理

    <Linux内核设计与实现>CHAPTER1,2阅读梳理 [学习时间:2.5hours] [学习内容:Linux内核简介——历史与现今版本:Linux内核源代码以及编译] CHAPTER1 ...

  10. 探索.git目录

    .git目录 下面就开始进入.git目录,通过“ls”命令可以看到.git目录中的文件和子目录: 对于这些文件和目录,下面给出了一些基本的描述. hooks:这个目录存放一些shell脚本,可以设置特 ...