我的html页面中有一堆div标签。现在,我需要编写一个jQuery来计算网格的值。在下面的示例中,我将使用grid0作为基本ID,并且我希望该系列中的计数为1。
<div id="grid00">0</div>
<div id="grid01">0</div>
<div id="grid02">0</div>
<div id="grid03">1</div>
<div id="grid04">0</div>
<div id="grid05">0</div>
在下面给出的另一个示例中,我将使用以grid1开头的id,总值为6。请指导我!
<div id="grid10">5</div>
<div id="grid11">0</div>
<div id="grid12">0</div>
<div id="grid13">1</div>
<div id="grid14">0</div>
<div id="grid15">0</div>
我尝试了这个
jQuery("div[id^='grid0']")
。但这给了我所有的要素。但是我需要使用其中的值进行计数。谢谢!
最佳答案
首先使用starts-with选择器选择div,然后遍历结果并计算转换为整数的文本值。
function GetSum(prefix) {
var sum = 0;
$("div[id^='" + prefix + "']").each(function(){
sum += parseInt($(this).text());
});
return sum;
}
var grid0Total = GetSum("grid0");
var grid1Total = GetSum("grid1");
或者,如果您想使用jQuery函数更进一步:
jQuery.extend({
gridSum: function(prefix) {
var sum = 0;
if(!!prefix) {
$("div[id^='" + prefix + "']").each(function(){
sum += parseInt($(this).text());
});
}
return sum;
}
});
那么你可以写:
var grid0Total = jQuery.gridSum("grid0");
var grid1Total = jQuery.gridSum("grid1");
您也可以像这样使用map()函数:
var sum = 0;
$("div[id^='" + prefix + "']").map(function(){
return sum += parseInt($(this).text());
});
return sum;
在此处查看它们的全部操作:http://jsfiddle.net/FpmFW/1/