<!DOCTYPE html>
<html>
<head>
<title> new document </title>
<meta http-equiv="Content-Type" content="text/html; charset=gbk"/>
</head>
<body>
<table border="1" width="50%" id="table">
<tr>
<th>学号</th>
<th>姓名</th>
</tr>
</table>
<input type="button" value="添加一行" onclick="addRow()"/>
<script type="text/javascript">
var table = document.getElementById("table");
function addRow() {
var row = document.createElement("tr");
table.appendChild(row);
for (var i = 0; i < 2; i++) {
var td = document.createElement("td");
row.appendChild(td);
var txt = document.createTextNode("点击输入");
td.appendChild(txt);
td.setAttribute("class","write");
}
//加一行绑定一行onlick事件
click_writeIn();
}
function click_writeIn() {
var dt_write = document.getElementsByClassName("write");
alert(dt_write.length);
for(var i=0;i<dt_write.length;i++){
dt_write[i].onclick=function () {
var newNode = document.createElement("input");
newNode.setAttribute("type","txt");
dt_write[i].parentNode.replaceChild(newNode,dt_write[i]);
}
}
}
</script>
</body>
</html>
求大神救命,检查了半天,38行一直报错,头都大了,我感觉逻辑都是对的
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
11条回答 默认 最新
- 伪造的时空 2017-03-09 00:49关注
for(var i=0;i<dt_write.length;i++) { dt_write[i].onclick=function () { var newNode = document.createElement("input"); newNode.setAttribute("type","txt"); dt_write[i].parentNode.replaceChild(newNode,dt_write[i]); } }
上面这段代码,当响应dt_write[i].onclick这个事件时,dt_write[i]的定义早就没了,因此dt_write[i].parentNode.replaceChild(newNode,dt_write[i]);这句肯定出错,把dt_write[i]改成this试一下:
for(var i=0;i<dt_write.length;i++) { dt_write[i].onclick=function () { var newNode = document.createElement("input"); newNode.setAttribute("type","txt"); this.parentNode.replaceChild(newNode,this); } }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥170 如图所示配置eNSP
- ¥20 docker里部署springboot项目,访问不到扬声器
- ¥15 netty整合springboot之后自动重连失效
- ¥15 悬赏!微信开发者工具报错,求帮改
- ¥20 wireshark抓不到vlan
- ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
- ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
- ¥15 stata安慰剂检验作图但是真实值不出现在图上
- ¥15 c程序不知道为什么得不到结果
- ¥15 键盘指令混乱情况下的启动盘系统重装