2

这是我在这里的第一个问题,如果有任何错误,请原谅我。

我正在尝试通过 JavaScript 向表中添加行。新添加的行将添加到倒数第二个位置,最后一行包含创建新行的按钮。最后一行的 id 为“submitrow”,但获取该元素并将其传递给 insertBefore 不知何故不起作用。将 lastChild 作为第二个参数传递给 insertBefore 也很奇怪。

在正文中,这是以下形式:

<form>
    <input type="hidden" name="submit_done" value="true" />
    <table id="formtable">
        <tr>
            <td>Number : </td>
            <td><input type="text" name="num[]" /></td>
        </tr>
        <tr id="submitrow">
            <td><input type="button" value="Add one more" onclick="addRow()" /></td>
            <td><input type="submit" value="Go!" /></td>
        </tr>
    </table>
</form>

这是JavaScript函数:

function addRow(){
    var new_tr  = document.createElement('tr');
    var new_td1     = document.createElement('td');
    var new_td2     = document.createElement('td');
    var new_input   = document.createElement('input');

    new_td1.innerHTML = 'Number : ';

    new_input.type = 'text';
    new_input.name = 'num[]';
    new_td2.appendChild(new_input);

    new_tr.appendChild(new_td2);
    new_tr.insertBefore(new_td1, new_td2);

    var formtable   = document.getElementById('formtable');
    var submitrow   = document.getElementById('submitrow');
    submitrow.style.backgroundColor='red'; /*Works fine, paints button row red*/
    formtable.insertBefore(new_tr, submitrow); /*fails, invalid argument*/
}

现在,问题是:

  1. insertBefore 在最后一行失败。请注意,在 new_tr 对象上也已尝试过 insertBefore,它工作正常。所以唯一可能的无效参数可以是 submitRow,在失败语句上方仅一行的地方成功地将 shich 涂成红色。

  2. 如果对于失败的调用,而不是submitrow, ifformtable.lastChild使用,它运行。但是不知何故 lastChild 也包括上排。这意味着,如果我再输入 4 行并在测试输入中输入 1、2、3、4、5,然后如果您点击“再添加一个”按钮,那么现在在 4 到 5 之间添加了一行!

我已经尝试了很多来推理它,但在这两种情况下都没有逻辑。

希望有解决办法,谢谢大家

印度阿拜巴韦

4

1 回答 1

6

标题应在“JavaScript DOM insertBefore 未正确使用”中更改。

这是因为,即使您没有放入 DOM,浏览器也会自动创建一个<tbody>元素来包装表格的行。因此,它恰好#formtable不是父级#submitrow,这就是您收到错误的原因。

试试这个:

formtable.tBodies[0].insertBefore(new_tr, submitrow);

或者,更一般地说:

submitrow.parentNode.insertBefore(new_tr, submitrow);

(在支持它的浏览器中,甚至还有这个:

submitrow.insertAdjacentElement("beforeBegin", new_tr);

Internet Explorer、Chrome、Safari 和 Opera 支持它,Firefox 不支持,但它可以轻松填充。无论如何,我不建议使用这些东西。)

而且,作为一般建议,在写下表格时始终使用标签:<tbody>

<table id="formtable">
    <tbody>
        <tr>
            <td>Number : </td>
            <td><input type="text" name="num[]" /></td>
        </tr>
        <tr id="submitrow">
            <td><input type="button" value="Add one more" onclick="addRow()" /></td>
            <td><input type="submit" value="Go!" /></td>
        </tr>
    </tbody>
</table>

当然,<thead><tfoot>你需要它们时。

于 2012-09-07T08:29:06.227 回答