javascript - Detect html table cell value change - Stack Overflow

How am I able to detect change in html table on any cell? Currently I can only detect change in one cel

How am I able to detect change in html table on any cell? Currently I can only detect change in one cell, I could repeat the same code for all table cell ID but wondering if there is an efficient way.

Note that I have other inputs in my form and only wish to detect ones relevant to the table below:

Code:

html:

<table id="myTable" border="1" data-mini="true" >
<tbody>
<tr>
<th>Drawing Number</th>
<th>Description</th>
<th>Sheet Number</th>
<th>Issue</th>
</tr>
<tr>
<td><input name="drawing-n-1" id="drawing-n-1" type="text" /></td>
<td><input name="drawing-d-1" type="text" /></td>
<td><input name="drawing-s-1" type="text" /></td>
<td><input name="drawing-i-1" type="text" /></td>
<td><input name="drawing-n-2" id="drawing-n-2" type="text" /></td>
<td><input name="drawing-d-2" type="text" /></td>
<td><input name="drawing-s-2" type="text" /></td>
<td><input name="drawing-i-2" type="text" /></td>
</tr>
</tbody>
</table>

javascript:

var drawing_input = 'drawing-n-1';
$('#'+drawing_input).change(function(e) {
    alert("aha");
    var data = $('#'+drawing_input).val();
});

How am I able to detect change in html table on any cell? Currently I can only detect change in one cell, I could repeat the same code for all table cell ID but wondering if there is an efficient way.

Note that I have other inputs in my form and only wish to detect ones relevant to the table below:

Code:

html:

<table id="myTable" border="1" data-mini="true" >
<tbody>
<tr>
<th>Drawing Number</th>
<th>Description</th>
<th>Sheet Number</th>
<th>Issue</th>
</tr>
<tr>
<td><input name="drawing-n-1" id="drawing-n-1" type="text" /></td>
<td><input name="drawing-d-1" type="text" /></td>
<td><input name="drawing-s-1" type="text" /></td>
<td><input name="drawing-i-1" type="text" /></td>
<td><input name="drawing-n-2" id="drawing-n-2" type="text" /></td>
<td><input name="drawing-d-2" type="text" /></td>
<td><input name="drawing-s-2" type="text" /></td>
<td><input name="drawing-i-2" type="text" /></td>
</tr>
</tbody>
</table>

javascript:

var drawing_input = 'drawing-n-1';
$('#'+drawing_input).change(function(e) {
    alert("aha");
    var data = $('#'+drawing_input).val();
});
Share Improve this question edited Dec 5, 2017 at 7:41 Brian Tompsett - 汤莱恩 5,89372 gold badges61 silver badges133 bronze badges asked Dec 5, 2017 at 1:24 OssamaOssama 2,4438 gold badges46 silver badges90 bronze badges 4
  • event delegation – epascarello Commented Dec 5, 2017 at 1:25
  • Only input with id or every input in table? – Thum Choon Tat Commented Dec 5, 2017 at 1:27
  • with id only please – Ossama Commented Dec 5, 2017 at 1:27
  • id in the format above – Ossama Commented Dec 5, 2017 at 1:28
Add a ment  | 

2 Answers 2

Reset to default 3

With jQuery you needn't be so specific. Just change the selector to listen for all <input>s.

$('input').on('change',

This selector will pick every <input> on the page.

Or if you need to isolate the table's inputs, add the table's id in the selector.

$('#xTable input').on('change'...

This selector will pick every <input> within the table.

Saw that you needed only to listen for inputs with ids. If so then you can use the brackets and ^=:

$("#xTable input[id^='drawing-n-']").on('change'....

This means get any <input> that has an [ id that starts ^= with "drawing-n-" ] which is in a <table> with the id of xTable.

That selector will pick only input#drawing-n-1 and input#drawing-n-2

Demo

$("#xTable input[id^='drawing-n-']").on('change', function(e) {
  var data = $(this).val();
  console.log(data);
});
<table id="xTable" border="1" data-mini="true">
  <tbody>
    <tr>
      <th>Drawing Number</th>
      <th>Description</th>
      <th>Sheet Number</th>
      <th>Issue</th>

    </tr>
    <tr>
      <td><input name="drawing-n-1" id="drawing-n-1" type="text" /></td>
      <td><input name="drawing-d-1" type="text" /></td>
      <td><input name="drawing-s-1" type="text" /></td>
      <td><input name="drawing-i-1" type="text" /></td>
      <td><input name="drawing-n-2" id="drawing-n-2" type="text" /></td>
      <td><input name="drawing-d-2" type="text" /></td>
      <td><input name="drawing-s-2" type="text" /></td>
      <td><input name="drawing-i-2" type="text" /></td>
    </tr>
  </tbody>
</table>



<script src="https://ajax.googleapis./ajax/libs/jquery/2.1.1/jquery.min.js"></script>

event delegation

$("tbody").on("change", "input", function () {
    console.log(this.name, this.value)
});

发布者:admin,转转请注明出处:http://www.yc00.com/questions/1744791642a4593951.html

相关推荐

  • javascript - Detect html table cell value change - Stack Overflow

    How am I able to detect change in html table on any cell? Currently I can only detect change in one cel

    10小时前
    20

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信