从每行的复选框中,如果选中它,我想更新该行的表数据值。我尝试过:
$('#'+id).each(function(index, cell){
$('#data2').html("New Value");
});
但它不起作用。我通过以下方式访问ID:
if ($('.cbox1:checked').length) {
var id = '';
$('.cbox1:checked').each(function () {
id = $(this).val();
});
}
我的Html是
<table class="mytable" id="tableid" >
<tr>
<th style="width: 10px;"> </th>
<th> DATA1</th>
<th>DATA2</th>
<th>DATA3 </th>
</tr>
<tr contenteditable="false" class="content193" id="193">
<td> <input class="cbox1" type="checkbox" value="193"></td>
<td id="data1">45</td>
<td id="data2">566</td>
<td id="data3"> 12.12.2016</td>
</tr>
<tr contenteditable="false" class="content194" id="194">
<td><input class="cbox1" type="checkbox" value="194"></td>
<td id="data1">456</td>
<td id="data2">6745</td>
<td id="data3"> 11.10.2016</td>
</tr>
<tr contenteditable="false" class="content199" id="199">
<td><input class="cbox1" type="checkbox" value="199"></td>
<td id="data1">tr</td>
<td id="data2">24</td>
<td id="data3"> 20.01.2015</td>
</tr>
<tr contenteditable="false" class="content201" id="201">
<td><input class="cbox1" type="checkbox" value="201"></td>
<td id="data1">tr</td>
<td id="data2">24</td>
<td id="data3"> 20.01.2015</td>
</tr>
</table>
答案 0 :(得分:1)
根本不需要类或ID。您可以找到最接近已更改元素的行,只需直接访问它td
:
$('.cbox1').change(function(){
var $row = $(this).closest('tr'); //get the current row
$row.find('td').eq(1).text('new value'); // change first cell
$row.find('td').eq(2).text('new value'); // change second cell
$row.find('td').eq(3).text('new value'); // change third cell
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<table class="mytable" id="tableid" >
<tr>
<th style="width: 10px;"> </th>
<th> DATA1</th>
<th>DATA2</th>
<th>DATA3 </th>
</tr>
<tr contenteditable="false" class="content193" id="193">
<td> <input class="cbox1" type="checkbox" value="193"></td>
<td>45</td>
<td>566</td>
<td> 12.12.2016</td>
</tr>
<tr contenteditable="false" class="content194" id="194">
<td><input class="cbox1" type="checkbox" value="194"></td>
<td>456</td>
<td>6745</td>
<td> 11.10.2016</td>
</tr>
<tr contenteditable="false" class="content199" id="199">
<td><input class="cbox1" type="checkbox" value="199"></td>
<td>19</td>
<td>24</td>
<td> 20.01.2015</td>
</tr>
<tr contenteditable="false" class="content201" id="201">
<td><input class="cbox1" type="checkbox" value="201"></td>
<td>15</td>
<td>24</td>
<td> 20.01.2015</td>
</tr>
</table>
答案 1 :(得分:0)
对每行重复的元素使用类而不是ID。然后让选择器查找所选行中的类。
$("#doit").click(function() {
$('.cbox1:checked').each(function() {
var id = $(this).val();
$('#' + id + ' .data2').html("New Value");
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<table class="mytable" id="tableid">
<tr>
<th style="width: 10px;"></th>
<th>DATA1</th>
<th>DATA2</th>
<th>DATA3</th>
</tr>
<tr contenteditable="false" class="content193" id="193">
<td>
<input class="cbox1" type="checkbox" value="193">
</td>
<td class="data1">45</td>
<td class="data2">566</td>
<td class="data3">12.12.2016</td>
</tr>
<tr contenteditable="false" class="content194" id="194">
<td>
<input class="cbox1" type="checkbox" value="194">
</td>
<td class="data1">456</td>
<td class="data2">6745</td>
<td class="data3">11.10.2016</td>
</tr>
<tr contenteditable="false" class="content199" id="199">
<td>
<input class="cbox1" type="checkbox" value="199">
</td>
<td class="data1">tr</td>
<td class="data2">24</td>
<td class="data3">20.01.2015</td>
</tr>
<tr contenteditable="false" class="content201" id="201">
<td>
<input class="cbox1" type="checkbox" value="201">
</td>
<td class="data1">tr</td>
<td class="data2">24</td>
<td class="data3">20.01.2015</td>
</tr>
</table>
<button id="doit">Click me</button>