这个可能是我对html5缺乏经验,但我有一些代码可以很好地使用Javascript和TBODY标记节点动态地向表添加行,但是当我有多个表(我这样做)时在输入数据时我需要动态填充的页面....它不起作用...
我的问题是我无法弄清楚如何参考我想要添加信息的部分。
我尝试创建一个带有特定标记的节点,但它不是一个可识别的标记,因此它添加了数据但不在表格内...奇怪的是。
这是我正在使用的Javascript代码
document.getElementById("sendNoteToDispatch").onclick=function()
{
event.preventDefault();
console.log("Made it to note entry.");
var noteTxt = $('#noteEntry').val();
var noteEntBy = 'BGM';
var nowNote = Date();
var noteEntDate = dateFormat(nowNote, "mm/dd/yyyy HH:MM:ss");
if (!document.getElementsByTagName) return;
tabBody=document.getElementsByTagName("TBODY").item(0);
row=document.createElement("TR");
cell1=document.createElement("TD");
cell2=document.createElement("TD");
cell3=document.createElement("TD");
textnode1=document.createTextNode(noteEntDate);
textnode2=document.createTextNode(noteEntBy);
textnode3=document.createTextNode(noteTxt);
cell1.appendChild(textnode1);
cell2.appendChild(textnode2);
cell3.appendChild(textnode3);
row.appendChild(cell1);
row.appendChild(cell2);
row.appendChild(cell3);
tabBody.appendChild(row);
document.getElementById("noteEntry").value = '';
document.getElementById("noteEntry").focus();
}
});
这是它使用的html代码。
<div id="Notes" class='acceptEnterNotes'>
<form>
<input type="text" name="noteEntry" id="noteEntry" class="noteEntryField" placeholder="Note Entry" size="115" />
<button type="submit" id="sendNoteToDispatch" class="noteEntryButton buttonAddNote" value="Submit">
Submit Note
</button>
</form>
<br />
<br />
<div id="filterNotesGriddiv">
<input type="text" name="filterNotesGrid" id="filterNotesGrid" class="tableFilterInput" size="75" placeholder="Search the Table Below..." />
</div>
<div id="notesEntered">
<table id="notesEnteredGrid" class="lowerSectionTable">
<tbody>
<tr class="enteredNotesHeader">
<td class="tableHeaderCells cellDateEntered">Date Entered</td><td class="tableHeaderCells cellEnteredBy">Entered by</td><td class="tableHeaderCells cellNoteEntered">Note</td>
</tr>
</tbody>
</table>
</div>
</div>
我尝试将tbody标签更改为类似于tbodyNotes,但是没有用,然后我尝试向tbody节点添加ID,但这也不起作用......所以任何可以帮助的东西,所以我可以用另一个表添加另一个部分...会很棒。
答案 0 :(得分:2)
所以目前你在页面中获得了第一个TBODY标签:
tabBody=document.getElementsByTagName("TBODY").item(0);
然后构建一行单元格,然后将该行插入到tbody中:
tabBody.appendChild(row);
如果您将另一个表放入页面中,其中包含TBODY,则可以使用以下内容获取第二个表的TBODY标记:
tabBody2=document.getElementsByTagName("TBODY").item(1);
总的来说,你似乎使用了大量的猜测和(可能)剪切和粘贴的代码。当你说你尝试过ID并且它们不起作用时,这有点荒谬。元素上的ID工作正常,甚至是TBODY标签。如果有疑问,请先尝试从firebug或chromebug控制台调用它们,然后获取代码行以使TBODY标记首先在那里工作,然后将其放入代码中。 试试这个:将两个带tbody的表放入你的html页面。给tbody标签id,比如“tbody1”和“tbody2”,然后打开你的firebug控制台并输入: 的document.getElementById( “tbody1”) 将鼠标悬停在结果上以查看页面中的元素是否突出显示。然后尝试使用tbody2。
最后,这些都不是HTML5,它只是简单的老无聊的HTML和Javascript。您可以在mozilla dev上查看DOM API级别2,HTML4规范和Javascript参考,以了解有关这些命令的更多信息。