javascript - 如何在JavaScript中获取表格所有行的选定选项值?

标签 javascript html html-table cell

我有一个使用动态生成的数据创建的 HTML 表,每行都有不同的 ID。每行包含 3 列,其中 2 列是文本输入字段,1 列是选择字段。

我想要做的是获取表格每一行的所有内容,但我无法获取所选选项的值。我使用 for 循环来迭代每行的每列值。

我获得了前两个输入字段的正确值,但选择字段给出了未定义值。

如何获取每个选择字段的选定选项值?

function getData(){
  var table = document.getElementById("dataTable");
    for (var i = 1, row; row = table.rows[i]; i++) {
        var x = row.cells[0].childNodes[0].value;
        var y = row.cells[1].childNodes[0].value;
        var z = row.cells[2].childNodes[0].value; // select option field
        
    }
}
<td><input value="first" id="first1" name="first[]" /></td>
<td><input value="second" id="second1" name="second[]" /></td>
<td>
  <select name="third[]" id="third1">
    <option value="option1">One</option>
    <option value="option2">Two</option>
  </select>
</td>

最佳答案

选择字段似乎是表格单元格的第二个子字段,因此由 childNodes[1] 访问。

第一种情况演示:

function getData(){
  var table = document.getElementById("dataTable");
    var row;
    for (var i = 0,  row = table.rows[i]; i < table.rows.length ;i++) {
        console.log('here')
        var x = row.cells[0].childNodes[0].value;
        var y = row.cells[1].childNodes[0].value;
        var z = row.cells[2].childNodes[1].value; // select option field
        console.log(x,y,z)
    }
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<table id="dataTable">
<tr>
<td><input value="first" id="first1" name="first[]" /></td>
<td><input value="second" id="second1" name="second[]" /></td>
<td>
  <select name="third[]" id="third1">
    <option value="option1">One</option>
    <option value="option2">Two</option>
  </select>
</td>
</tr>
</table>
<button onclick="getData()">Click</button>

发生这种情况的原因是 <td> <select> 之间有额外的空格。 。删除它们,可以通过 childNodes[0] 访问它

function getData(){
  var table = document.getElementById("dataTable");
    
    var row;
    for (var i = 0,  row = table.rows[i]; i < table.rows.length ;i++) {
        var x = row.cells[0].childNodes[0].value;
        var y = row.cells[1].childNodes[0].value;
        var z = row.cells[2].childNodes[0].value; // select option field
        
    }
}
<table id="dataTable">
<tr>
<td><input value="first" id="first1" name="first[]" /></td>
<td><input value="second" id="second1" name="second[]" /></td>
<td><select name="third[]" id="third1">
    <option value="option1">One</option>
    <option value="option2">Two</option>
</select>
</td>
</tr>
</table>
<button onclick="getData()">Click</button>

您还需要结束 for 循环,从而对行数设置条件

关于javascript - 如何在JavaScript中获取表格所有行的选定选项值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43094914/

相关文章:

javascript - 将按钮移出容器时,单击时克隆 div 会中断吗?

javascript - 尝试为我的 HTML 游戏创造最快时间的高分

javascript - 具有多个 div 的页面验证

html - 表格中 <td> 元素下的 CSS 三 Angular 形

javascript - 如何在 Div 中按下按钮

javascript - 如何将此 Node 代码分解为不同的文件

css - 如何在 HTML5 的内联上下文中嵌套 block 元素?

html - 重复使用带过滤器的背景图像

css - 获取 div 以填充表格单元格

css - 你会怎么做 : Tables or CSS?