为了账号安全,请及时绑定邮箱和手机立即绑定

使用JS更改表tr元素

使用JS更改表tr元素

互换的青春 2024-01-03 15:46:00
我正在尝试更改函数中的一些表格单元格,我已将其简化为这个简短的片段,以帮助我了解出了什么问题。我基本上需要在已识别的<tr>表行上使用列索引并更改该单元格中显示的值。我已经尝试过,通过查看访问表行的各种代码,tr.col[1].innerHTML = "NEW NAME";tr.cell[1].innerHTML = "NEW NAME";另外,我目前正在使用 jQuery,因为这是 ajax 调用的一部分,但这可能会使事情变得复杂。我是 JS 和 jQuery 的新手,不知道哪些部分是哪些(我知道var tr = $('#tbl_id_4')没有 jQuery 就无法工作function ChangeName(){    alert('Clicked');    var tr = $('#tbl_id_4');    tr[1].innerHTML = "NEW NAME";}<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script><table id="JrmTable">  <thead>    <tr>      <th>Id</th>      <th>Name</th>    </tr>  </thead>  <tbody>    <tr id="tbl_id_1">      <td>1</td>      <td>Peter</td>    </tr>    <tr id="tbl_id_4">      <td>4</td>      <td>Paul</td>    </tr>  </tbody></table><input type="button" onclick="ChangeName()" value="Click Me" />
查看完整描述

1 回答

?
慕姐8265434

TA贡献1813条经验 获得超2个赞

您正在元素上使用索引访问器#tbl_id_4。因此,您正在寻找带有 that 的第二个元素id,它显然不存在,也不可能存在。


要解决此问题,您需要children()查看tr. 另请注意此示例中使用了不显眼的事件处理程序。内联事件属性不再是良好实践,应尽可能避免。


document.querySelector('.button').addEventListener('click', function() {

  var tr = $('#tbl_id_4');

  tr.children()[1].innerHTML = "NEW NAME";

});

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<table id="JrmTable">

  <thead>

    <tr>

      <th>Id</th>

      <th>Name</th>

    </tr>

  </thead>

  <tbody>

    <tr id="tbl_id_1">

      <td>1</td>

      <td>Peter</td>

    </tr>

    <tr id="tbl_id_4">

      <td>4</td>

      <td>Paul</td>

    </tr>

  </tbody>

</table>

<input type="button" class="button" value="Click Me" />


还值得注意的是,由于您已经在使用 jQuery,因此您可以这样做:


$('.button').on('click', function() {

  $('#tbl_id_4 td:eq(1)').text("NEW NAME");

});

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<table id="JrmTable">

  <thead>

    <tr>

      <th>Id</th>

      <th>Name</th>

    </tr>

  </thead>

  <tbody>

    <tr id="tbl_id_1">

      <td>1</td>

      <td>Peter</td>

    </tr>

    <tr id="tbl_id_4">

      <td>4</td>

      <td>Paul</td>

    </tr>

  </tbody>

</table>

<input type="button" class="button" value="Click Me" />


查看完整回答
反对 回复 2024-01-03
  • 1 回答
  • 0 关注
  • 102 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信