我有类似this的json。在JSON有对象名称tipe
,我想总结act_qty1
,act_val1
,acvqty
,acvval
,budqty
,budval
,cm_val1
,cm_val2
,cm_val3
在同一TIPE(例如,总结他们在那里他们tipe
是 “ESL”)。如何在javascript中求和?它可以用循环完成吗?如何从几个条件(例如,来自对象“TYPE”的值是“ABC”)的特定json对象中求和值?
这里是我到目前为止做出:
function detail(kodenegara, koderesult)
{
$.mobile.showPageLoadingMsg();
$.ajax({
type: "GET",
contentType: "application/json; charset=utf-8",
url: "http://www.greenfields.co.id:502/Service1.svc/"+kodenegara,
dataType: "json",
success:function(data){
var result = koderesult;
var details = "";
for (i = 0; i < data[result].length; i++){
$("#"+data[result][i].tipe).empty();
}
for (i = 0, types={} ; i < data[result].length; i++){
$("#"+data[result][i].tipe).append("<tr>"+
"<td>"+data[result][i].mc+"</td>"+
"<td>"+data[result][i].value3+"</td>"+
"<td>"+data[result][i].value2+"</td>"+
"<td>"+data[result][i].value1+"</td>"+
"<td>"+data[result][i].avgqty+"</td>"+
"<td>"+data[result][i].budqty+"</td>"+
"<td>"+data[result][i].budval+"</td>"+
"<td>"+data[result][i].acvqty+"</td>"+
"<td>"+data[result][i].acvval+"</td>"+
"</tr>").trigger('create');
//----------------------------------//
// HERE IS what I've made TO SUM THE VALUES //
//vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv//
for(i = 0; i < data[result].length; i++) {
if(data[result][i].tipe == 'ESL')
{
//how to summing data[result][i].cm_val3 where data[result][i].tipe == 'ESL'
var b = i + 1;
var test = parseInt(data[result][i].cm_val3) + parseInt(data[result][b].cm_val3)
}
}
}
//show the page
$.mobile.changePage("#detail_"+kodenegara, "slide", false, true);
},
error: function() {
alert("ERROR");
}
});
}
我不知道怎么写正确的循环求和的价值,同时tipe
是“ESL”(或“ESL1L”或“WHP “ 要不然)。如果我使用这个:
var b = i + 1;
var test = parseInt(data[result][i].cm_val3) + parseInt(data[result][b].cm_val3)
只有最后一个数组的总和。如何编写正确的循环以与该条件相加?
它完美:d这恰恰正是我需要的。非常感谢你的队友:) – blankon91 2012-07-13 09:27:13
打开萤火虫,看看打印出来的是什么 – 2012-07-13 09:29:32
再次感谢您的答案,但我再次遇到问题,我想从这些总结中分离出一些数值[mc](例如If 'mc'的数量是5,那么我想要'parseFloat(SumByTipe ['ESL'] ['cm1_per1_total])/ 5')怎么做?谢谢:) – blankon91 2012-07-18 01:15:45