我有以下代码用于生成动态html,它可以接受来自用户的输入,我想验证这个表的输入,我试图在Javascript函数中添加输入id,但它不起作用,你能建议吗?有什么方法可以达到这个目的吗?
HTML:
<th>Number of BPIs: <title="Number of BPIs"></th>
<td><select id="numberbpis" name="numberbpis" onchange="buildTable(this.value)">
<option value="1">1</option >
<option value="2">2</option >
<option value="3">3</option >
<option value="4">4</option >
<option value="5">5</option >
<option value="6">6</option >
<option value="7">7</option >
<option value="8">8</option >
<option value="9">9</option >
</select></td>
</tr>
<table id="contentTable" border="1">
<!-- Fill table programmatically -->
</table>
使用Javascript:
function buildTable(val) {
var myTable =document.getElementById("contentTable");
var j=val;
var rows = [];
var cells = [];
while (myTable.hasChildNodes()) {
myTable.removeChild(myTable.lastChild);
}
for (var i = 0; i < 1; i++) {
rows[i] = myTable.insertRow(i);
if (i%3 == 2) rows[i].addClass("every3rdrow");
cells[i] = [];
for (var x = 0; x < j ; x++) {
cells[i][x] =document.createElement((x==0)?"th":"td");
cells[i][x].innerHTML = (x==0)?"<input>":"<input>";
rows[rows.length - 1].appendChild(cells[i][x]);
}
}
}
buildTable();
我尝试添加<input id="..." name="...">
,但这不起作用,您能否提出其他解决方案?
这是jsfiddle,我忘了在上面添加一些html代码,
我想在javascript函数中给输入一个输入id,这样我就可以使用该id来调用另一个javascript函数,但是当我给出&lt;输入id =“t1”&gt;,
动态表没有生成,请帮忙?
我会以这种方式验证正常输入,
function AdaptiveValidate(){
$adaptive = document.getElementById("adaptive").value;
if(!/^-?\d*$/.test($adaptive)) {
alert("Adaptive BPI vector(% capacity) value must be numeric!");
}
}
我想用它来验证尚未创建的表的元素吗?
以及如何从这个表中读取输入值?
答案 0 :(得分:0)
无法发表评论,但......
所以你只想要一个身份证?那么每个生成的都会显示从t0到tx? 我完成它的方式动态地为每个单元格添加一个id。这是你想要的? http://jsfiddle.net/J4KFQ/
for (var x = 0; x < j ; x++) {
cells[i][x] =document.createElement((x==0)?"th":"td");
cells[i][x].innerHTML = (x==0)?"<input id=t"+x+">":"<input id=t"+x+">";
rows[rows.length - 1].appendChild(cells[i][x]);
}