首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法使用document.getElementById获取动态生成单元的值

无法使用document.getElementById获取动态生成单元的值
EN

Stack Overflow用户
提问于 2015-03-28 10:23:15
回答 1查看 652关注 0票数 1

我使用下面的javascript代码将行添加到已经有2行的HTML表中:

代码语言:javascript
复制
<table id="dataTable" class="CSSTableGenerator">
        <tbody>
        <tr>
                <td><label>No.of internal corners</label></td>
                <td><input type="text" id="intCorner" class="corner"></td>
                <td><label>No.of external corners</label></td>
                <td><input type="text" id="extCorner" class="corner"></td>
        </tr>
        </tbody>
            <tr>
                <td><label>Wall 1</label></td>
                <td><label>Wall 2</label></td>
                <td><label>Wall 3</label></td>
                <td><label>Wall 4</label></td>
            </tr>
            <tr>
                <td><input type="text" id="wall00" class="wall"></td>
                <td><input type="text" id="wall01" class="wall"></td>
                <td><input type="text" id="wall02" class="wall"></td>
                <td><input type="text" id="wall03" class="wall"></td>
            </tr>
        </tbody>
    </table>
<input type="button" value="Add more walls" onclick="addRow('dataTable')">
function addRow(tableID) {
        var table = document.getElementById(tableID);
        var rowCount = table.rows.length;
        var row = table.insertRow(rowCount);
        var cell0 = row.insertCell(0);
        var element0 = document.createElement("input");
        element0.type = "text";
        element0.name = "txtbox[]";
        element0.className ="wall";
        element0.id="wall"+rowCount-2+"0";
        cell0.appendChild(element0);
        var cell1 = row.insertCell(1);
        var element1 = document.createElement("input");
        element1.type = "text";
        element1.name = "txtbox[]";
        element1.className ="wall";
        element1.id="wall"+rowCount-2+"1";
        cell1.appendChild(element1);
        var cell2 = row.insertCell(2);
        var element2 = document.createElement("input");
        element2.type = "text";
        element2.name = "txtbox[]";
        element2.className ="wall";
        element2.id="wall"+rowCount-2+"2";
        cell2.appendChild(element2);
        var cell3 = row.insertCell(3);
        var element3 = document.createElement("input");
        element3.type = "text";
        element3.name = "txtbox[]";
        element3.className ="wall";
        element3.id="wall"+rowCount-2+"3";
        cell3.appendChild(element3);
    }

但是,当我使用下面的代码获取动态添加的单元格的值时,它说document.getElementById()for循环中为null。它适用于HTML代码添加的单元格。

代码语言:javascript
复制
function sumOppositeWalls(){
        var table = document.getElementById('dataTable');
        var rowCount = table.rows.length;
        alert(rowCount);
        var minusCount=0;
        for(var i=0;i<rowCount-2;i++){
            var wall1=parseFloat(document.getElementById('wall'+i+'0').value);
            var wall2=parseFloat(document.getElementById('wall'+i+'1').value);
}

如果我做错了什么,请提出解决方案,或者让我知道。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-03-28 10:37:49

问题是如何为动态元素创建id

您正在使用数字减法和字符串连接(例如element2.id="wall"+rowCount-2+"2"; ),这是错误的。

您需要将数值计算分离成一个单独的单元,否则"wall"+rowCount将被处理给wall2,那么'wall2' - 1将是NaN,因为一个操作数不是一个数字,所以最终的结果将类似于NaN2

代码语言:javascript
复制
element2.id="wall"+(rowCount-2)+"2"; 

因为您在多个地方使用rowCount-2值,所以使用一个变量

代码语言:javascript
复制
var idCounter = rowCount - 2;

然后

代码语言:javascript
复制
element0.id = "wall" + idCounter + "0";

演示:小提琴

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29316008

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档