how2j.cn

关键字 简介 示例代码
removeChild
删除元素节点
示例代码
removeAttribute
删除属性节点
示例代码
removeChild
删除文本节点
示例代码
示例 1 : 删除元素节点   
示例 2 : 删除属性节点   
示例 3 : 删除文本节点   

示例 1 :

删除元素节点

要删除某个元素节点有两步
第一:先获取该元素的父节点
第二:通过父节点,调用removeChild 删除该节点
运行效果
<script> function removeDiv(){ var parentDiv = document.getElementById("parentDiv"); var div2= document.getElementById("div2"); parentDiv.removeChild(div2); } </script> <div id="parentDiv"> <div id="div1">安全的div</div> <div id="div2">即将被删除的div</div> </div> <button onclick="removeDiv()">删除第二个div</button>
<script>
function removeDiv(){
  var parentDiv = document.getElementById("parentDiv");
  var div2= document.getElementById("div2");
  parentDiv.removeChild(div2);
}

</script>

<div id="parentDiv">
  <div id="div1">安全的div</div>
  <div id="div2">即将被删除的div</div>
</div>

<button onclick="removeDiv()">删除第二个div</button>



源代码
1. 双击选中单词 2. 三击选中整行 3. CTRL+F 查找 4. F8 全屏编辑,再次点击恢复
渲染中 渲染完成
效果
示例 2 :

删除属性节点

要删除某个属性节点有两步
第一:先获取该元素节点
第二:元素节点,调用removeAttribute删除指定属性节点
运行效果
<script> function removeHref(){ var link= document.getElementById("link"); link.removeAttribute("href"); } </script> <a id="link" href="http://12306.com">http://12306.com</a> <br> <button onclick="removeHref()">删除超链的href属性</button>
<script>
function removeHref(){
  var link= document.getElementById("link");
  link.removeAttribute("href");
}

</script>

<a id="link" href="http://12306.com">http://12306.com</a>

<br>
<button onclick="removeHref()">删除超链的href属性</button>



源代码
1. 双击选中单词 2. 三击选中整行 3. CTRL+F 查找 4. F8 全屏编辑,再次点击恢复
渲染中 渲染完成
效果
示例 3 :

删除文本节点

删除文本节点
1. 通过childNodes[0] 获取文本节点
注:children()[0] 只能获取第一个子元素节点,不能获取文本节点
2. 通过removeChild删除该文本节点
但是这种方式比较麻烦,一般都是直接通过innerHTML设置为空即可。
注: 通过innerHTML=""的方式,同样会导致文本子节点被删除。
运行效果
<script> function removeDiv1(){ var parentDiv = document.getElementById("parentDiv"); var textNode = parentDiv.childNodes[0]; parentDiv.removeChild(textNode); } function removeDiv2(){ var parentDiv = document.getElementById("parentDiv"); parentDiv.innerHTML=""; } function recover(){ var parentDiv = document.getElementById("parentDiv"); parentDiv.innerHTML="这里是文本 "; } </script> <style> button{ display:block; } </style> <div id="parentDiv"> 这里是文本 </div> <button onclick="removeDiv1()">通过removechild删除div下的文本节点</button> <button onclick="removeDiv2()">通过innerHTML让内容置空</button> <button onclick="recover()">恢复内容</button>


源代码
1. 双击选中单词 2. 三击选中整行 3. CTRL+F 查找 4. F8 全屏编辑,再次点击恢复
渲染中 渲染完成
效果


HOW2J公众号,关注后实时获知布最新的教程和优惠活动,谢谢。


问答区域    
2017-12-28 var parentDiv = document.getElementById("parentDiv");这个好像没用吧
咸鱼王
var parentDiv = document.getElementById("parentDiv");删除了代码照常运行




1 个答案

哇哦 答案时间:2018-01-10
var div2= document.getElementById("div2"); document.removeChild(div2);//这么写的话上面那句的确是没用了 ---------------------- 但是按照站长大大的写法是有用的,要不会报找不到元素异常




答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到




2017-05-14 用innerHTML删除文本
ChenbXxx



用innerHTML=“”来删除div元素里的文本内容的时候好像会把子节点的全部删掉。 把div改成p之后又只删除p里面 不会删除子节点里面 这是什么原因。。
<div id="forTest">
	Hello
	<span>
		hello-3
	</span>
</div>
		
<button id="showCSS" onclick="removeText()">一个百搭的按钮</button>

	function removeText(){
				var divForTest = document.getElementById("forTest");
				divForTest.innerHTML=""
			}

							


1 个答案

how2j 答案时间:2017-05-15
为什么会觉得不会删除呢? 我用你的代码,并且使用p元素,一样可以删除: http://how2j.cn/code/164




答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到





2017-04-10 第三个例子这里




提问之前请登陆
关于 前端基础-HTML DOM-删除节点 的提问

尽量提供截图代码异常信息,有助于分析和解决问题。 也可进本站QQ群交流: 389538688
站长会在每个工作日早上尽量回答提问(如果有漏掉没有回答的,请进群提醒一下)
提问尽量提供完整的代码,环境描述,越是有利于问题的重现,您的问题越能更快得到解答。
对教程中代码有疑问,请提供是哪个步骤,哪一行有疑问,这样便于快速定位问题,提高问题得到解答的速度
站长是玻璃心,提问的时候请语气温柔些 kiss~
截止2017-5-19日累计提问 1638个,站长回答了 1546个
截止2017-8-15日累计提问 2788个,站长回答了 2544个

上传截图