2014-04-23 132 views
0

我有一個總結列和行的表,並顯示總和的結果。 我必須改變每個總的顏色。如果是,就把它放在「綠色」。如果是奇數,把它放在 「紅色」JQuery設置奇數,偶數總數

這是我的表:

<table id="sum_table"> 
    <tr> 
     <td><input value="0" class="sum1" /></td> 
     <td><input value="0" class="sum2"/></td> 
     <td><input value="0" class="sum3"/></td> 
     <td class="total">0</td> 
    </tr> 
    <tr> 
     <td><input value="0" class="sum1"/></td> 
     <td><input value="0" class="sum2"/></td> 
     <td><input value="0" class="sum3"/></td> 
     <td class="total">0</td> 
    </tr> 
    <tr> 
     <td><input value="0" class="sum1"/></td> 
     <td><input value="0" class="sum2"/></td> 
     <td><input value="0" class="sum3"/></td> 
     <td class="total">0</td> 
    </tr> 

    <tr class ="totalCol"> 
     <td>0</td> 
     <td>0</td> 
     <td>0</td> 
    </tr> 

</table> 
<button id="tabla">+</button> 

JQuery的:

//Sumamos las columnas 
    $(document).on('keyup change','#sum_table tr:not(.totalCol) input:text',function() { 
    var $table = $(this).closest('table'); 
    var total = 0; 
    var thisNumber = $(this).attr('class').match(/(\d+)/)[1]; 

    $table.find('tr:not(.totalCol) .sum'+thisNumber).each(function() { 
     total += parseInt(this.value); 
    }); 

    $table.find('.totalCol td:nth-child('+thisNumber+')').html(total); 
}); 


    //Añadimos filas y coumnas cuando se clica al boton "+". 
    $("#tabla").click(function() { 
     $("#sum_table tr:last-child").before("<tr>"+$("#sum_table tr:eq(0)").html()+"</tr>"); 
     $("tr:not(:last-child)").each(function() { 
      var classname = $(this).find("td:last-child").index() + 1; 
      $(this).find("td:last-child").before('<td><input class="sum' + classname + '" type="text" value="0"></td>'); 
     }); 
     $("#sum_table tr:last-child").append("<td>0</td>"); 
    }); 

//Creamos la funcion newSum para hacer la suma y mostrarlo en el total. 
$(document).on('keyup','input',newSum); 
function newSum() { 
    var sum = 0; 
    var thisRow = $(this).closest('tr'); 
    var total = 0; 

    $(thisRow).find("td:not(.total) input").each(function() { 
     sum += parseInt(this.value); 
    }); 
    $(thisRow).find(".total").html(sum); 
    $('.total').each(function() { 
     total += parseInt($(this).html()); 
    }); 
} 

DEMO JSFIDDLE

回答

2

試試這個,在newSum把下面這段代碼()功能

if ((this.value % 2 == 0)) { 
    $(this).css('color', 'green'); 
} else { 
    $(this).css('color', 'red'); 
} 

DEMO

+0

是的,它改變輸入文字的顏色,但我想改變顏色只總和的。 – Coluh

+0

@devtreat啊我看到了,然後把if語句添加之前像這樣的小提琴這裏http://jsfiddle.net/hdhZZ/5/ – Anton

+1

如果你不希望輸入值改變顏色可以按照這個http: //jsfiddle.net/hdhZZ/8/ – Anton

1

我已更新您的fiddle請檢查。

$(document).on('keyup change','#sum_table tr:not(.totalCol) input:text',function() { 
    var $table = $(this).closest('table'); 
    var total = 0; 
    var thisNumber = $(this).attr('class').match(/(\d+)/)[1]; 

    $table.find('tr:not(.totalCol) .sum'+thisNumber).each(function() { 
    total += parseInt(this.value); 
    }); 
    var total_field = $table.find('.totalCol td:nth-child('+thisNumber+')'); 
    total_field.html(total); 
    if(total % 2 == true) { 
    total_field.css("background","red"); 
    } 
    else { 
    total_field.css("background","green"); 
    } 
}); 
2

嘗試這種方式

jQuery代碼:

if (total % 2 == 0) 
     $table.find('.totalCol td:nth-child(' + thisNumber + ')').css('color', 'green'); //set green to even total 
    else 
     $table.find('.totalCol td:nth-child(' + thisNumber + ')').css('color', 'red'); //set red to odd total 

現場演示: http://jsfiddle.net/hdhZZ/7/

編碼快樂:)

1

每當一個輸入被改變,檢查是否總價值爲奇數或偶數... 這是粗糙的,我會切換的一類,而不是編輯的內嵌CSS ..

$('td input').on('change', function(){ 
    $('.totalCol td').each(function(){   
     var $total = parseInt($(this).html()); 
     if ($total !==0 && $total % 2 === 0) { 
      $(this).css('background-color','green'); 
     } 
     else { 
      $(this).css('background-color','#fff'); 
     } 
    }); 
}); 
2

我知道你已經接受了答案,但我建議重寫你的方法以下(雖然着色的方法是一樣的由其他答案建議):

function sumTotals(){ 
    // caching variables: 
    var table = $('#sum_table'), 
     inputRows = table.find('tr:not(.totalCol)'), 
     inputCells = inputRows.find('td:not(.total)'); 

    // iterating over each of the 'td' elements in the '.totalCol' row: 
    $('.totalCol td').each(function(i,e){ 

     /* i is the index of the current element over which we're iterating 
      among the collection returned by the selector, 
      e is the element (the 'this'), which we're not using here. 

      We're using ':nth-child()' to look at the 'input' elements from 
      each column, and creating an array of the values using 'map()' 
      and 'get()': */ 
     var sum = inputRows.find('td:nth-child(' + (i + 1) + ') input').map(function(){ 
      return parseFloat(this.value) || 0; 
     }).get().reduce(function (prev, curr) { 
     /* 'reduce()' allows us to perform a calculation (summation) of the 
      values in the returned array: */ 
      return prev + curr; 
     }); 

     // setting the text of the current 'td' to the sum, 
     // using CSS to set the color to either green (even) or red (odd): 
     $(this).text(sum).css('color', sum % 2 === 0 ? 'green' : 'red'); 
    }); 

    /* iterating over each of the rows with inputs, finding the 
     last 'td', and updating its text: */ 
    inputRows.find('td:last-child').text(function(){ 
     // caching: 
     var $this = $(this), 
      /* getting all the previous 'td' elements, and their 'input' 
       descendant elements, mapping their values: */ 
      sum = $this.prevAll('td').find('input').map(function(){ 
      return parseFloat(this.value) || 0; 
     }).get().reduce(function (prev, curr) { 
      return prev + curr; 
     }); 

     // setting the color (as above): 
     $this.css('color', sum % 2 === 0 ? 'green' : 'red'); 
     return sum; 
    }); 
} 

$('#sum_table').on('keyup change input paste', 'tr:not(.totalCol) input', sumTotals); 

JS Fiddle demo

參考文獻:

+0

真棒代碼大衛托馬斯!我現在要試試:) – Coluh

+1

謝謝,我希望它對你有用! :) –

+1

出於好奇,爲您的用例做了這項工作? (不尋找接受,特別是,但只是想知道我的代碼是否需要以任何方式改進。) –