为了账号安全,请及时绑定邮箱和手机立即绑定

为什么在删除节点的方法中写了输出语句,其他的元素节点会消失?

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>无标题文档</title>
</head>

<body>
<div id="content">
  <h1>html</h1>
  <h1>php</h1>
  <h1>javascript</h1>
  <h1>jquery</h1>
  <h1>java</h1>
</div>
<script type="text/javascript">
function clearText() {
  var content=document.getElementById("content");
  // 在此完成该函数
  var childs = content.childNodes;
  for(var i =0;i<childs.length;){
      var x= content.removeChild(childs[i]);
      if(x.nodeType==1){

          document.write(x.innerHTML+"<br/>");//如果加上这句点击清除节点内容,这个按钮会消失

      }
  }
}
</script>
<button onclick="clearText()">清除节点内容</button>
</body>
</html>

正在回答

1 回答

因为 你这部分代码:

 if(x.nodeType==1){

          document.write(x.innerHTML+"<br/>");//如果加上这句点击清除节点内容,这个按钮会消失

      }

是输出清除后的元素的内容,所以按钮就不见了,按钮不是元素。

1 回复 有任何疑惑可以回复我~
#1

qq_丨银丨_0 提问者

那加上一个<p>123</p>元素,和按钮一起都消失了,输出的内容会覆盖原网页的东西吗?
2016-08-26 回复 有任何疑惑可以回复我~
#2

慕盖茨6170990 回复 qq_丨银丨_0 提问者

对啊,
2016-09-06 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

为什么在删除节点的方法中写了输出语句,其他的元素节点会消失?

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信