0

如果容器 Div 设置为显示块,我正在考虑如何通过 jQuery 将具有特定名称的所有输入值相加。

东西链接if ($('#product_' + this.alt).css('display','block')) {

然后它需要加起来.each像这样获取输入。

$('#product_price_total_PRI_' + this.alt).val

关于如何将所有这些放在一起的任何想法?

编辑:

显然我应该澄清一下。包含在多个复选框和单选按钮的 alt 标记中的是一个 ID,它对应于隐藏容器和字段的 ID。因此,被选中的按钮和复选框的组合决定了哪些隐藏区域是可见的,如此处所示。

function product_analysis_global() {
$(':checked').each(function(){
    $('#product_' + this.alt).css('display','block');
    $('#product_quantity_PRI_' + this.alt).val(this.value);
    var quantity = $('#product_quantity_PRI_' + this.alt).val();
    var price = $('#product_price_PRI_' + this.alt).val();
    var duration = $('#product_duration_PRI_' + this.alt).val();
    var dives = $('#product_dives_PRI_' + this.alt).val();
    var hire = $('#product_quantity_PRI_' + this.alt).val();

    $('#product_price_total_PRI_' + this.alt).val(price * quantity);
    $('#product_duration_total_PRI_' + this.alt).val(duration * quantity);
    $('#product_dives_total_PRI_' + this.alt).val(dives * quantity);
    $('#product_hire_total_PRI_' + this.alt).val(hire * quantity);

}); 

我需要的是一个名为“GT_grand_total”的字段,它是'#product_price_total_PRI_' + this.alt).val()'仅当面板'#product_' + this.alt可见时该区域的所有字段的总和。

4

3 回答 3

1
var sum = 0;
$("#specific_name_1, #specific_name_2").not(":hidden").each(function(){
    var i = parseInt($(this).val(), 10);
    if(i){
        sum += i;
    }
});
$("#grand_total").val(sum);

:hidden 选择器的定义 http://api.jquery.com/hidden-selector/

于 2011-01-26T13:41:11.793 回答
1

如果非块显示项不可见,可以使用jquery:visible选择器

if ($('#product_' + this.alt).is(":visible")) {...}

http://api.jquery.com/visible-selector/

于 2011-01-26T13:42:03.260 回答
1

根据您的要求

var arr = $("div[id*='product_']").not(":hidden").map(function(){
  return $(this).find("input[id*='product_price_total_PRI_']").val();
}).get(); 



var total = 0;
$.each(arr,function() {
    total += parseInt(this);
});
alert(total);

或总计

var total = eval(arr.join('+'));

alert(total);

工作示例

http://jsfiddle.net/wB5Hh/2/

于 2011-01-26T14:20:07.090 回答