使用removeChild时注意

本文记录了一个关于使用removeChild删除动态添加的表单元素时遇到的问题。作者原本希望通过for循环遍历document.getElementsByName()获取的元素并逐个删除,却发现这种方法只删除了部分元素。文章详细解释了这一现象的原因,并提出了正确的解决办法。

        今天因为一个小问题确搞了好久,问题就出在removeChild上。根据项目的需要,之前动态添加的表单内容现在要动态的删除掉,我就想当然的使用document.getElementsByName()取到相应的表单内容给以个数组变量,然后根据这个数组变量的长度用一个for循环去removeChild。我认为很正常的程序变得很不正常,removeChild后的结果发现只能remove掉一般的对象,并且是remove的对象是间隔的,比如,remove掉了1、3、5、7.。。,而2、4、6.。。。。还是存在的。经过n小时的查错(俺笨),才找到原因,原来每remove掉一个对象后,第一个对象是去掉了,原来的document.getElementsByName()得到的集合中的第二个对象变成了第一个,以此类推。其length也-1了,所以我for第二次循环时实际移除的是一开始的第3个对象,后面以此类推。听得懂么???哈哈,反正我明白就行了。

想必对DOM更加熟悉的人不会犯这种低级错误,不过我还很“嫩”哈 哈哈哈哈 ,慢慢来吧

P.S:以后再通过循环使用removeChild时应该通过foreach来判断循环次数,这样就不会出错了。如果使用for的话,就每次都删第一个就ok了。

`removeChild` 是 DOM(文档对象模型)中用于移除子节点的方法。它通常用于操作 HTML 文档中的元素节点。以下是 `removeChild` 方法的详细介绍和使用示例: ### `removeChild` 方法介绍 `removeChild` 方法用于从父节点中移除指定的子节点。该方法属于父节点对象,通过父节点调用,并接收要移除的子节点作为参数。 ### 语法 ```javascript parentNode.removeChild(childNode); ``` - `parentNode`:要移除子节点的父节点。 - `childNode`:要移除的子节点。 ### 使用示例 假设有以下 HTML 结构: ```html <div id="parent"> <p id="child">这是一个子节点</p> </div> ``` 我们可以使用 JavaScript 来移除这个子节点: ```javascript // 获取父节点 var parent = document.getElementById("parent"); // 获取要移除的子节点 var child = document.getElementById("child"); // 移除子节点 parent.removeChild(child); ``` ### 注意事项 1. **父节点必须存在**:要移除子节点,必须确保父节点存在且正确获取。 2. **子节点必须是父节点的直接子节点**:要移除的子节点必须是父节点的直接子节点,而不是孙节点或其他后代节点。 3. **移除后的节点仍然存在**:被移除的节点仍然存在于内存中,可以重新添加到 DOM 中。 ### 重新添加被移除的节点 被移除的节点可以通过 `appendChild` 或 `insertBefore` 方法重新添加到 DOM 中: ```javascript // 重新添加被移除的节点 parent.appendChild(child); ``` ### 完整示例 以下是一个完整的示例,展示如何使用 `removeChild` 方法移除一个子节点并重新添加它: ```html <!DOCTYPE html> <html> <head> <title>removeChild 示例</title> </head> <body> <div id="parent"> <p id="child">这是一个子节点</p> </div> <button onclick="removeChildNode()">移除子节点</button> <button onclick="addChildNode()">重新添加子节点</button> <script> function removeChildNode() { var parent = document.getElementById("parent"); var child = document.getElementById("child"); parent.removeChild(child); } function addChildNode() { var parent = document.getElementById("parent"); var child = document.getElementById("child"); parent.appendChild(child); } </script> </body> </html> ``` 通过这个示例,你可以点击按钮来移除和重新添加子节点。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值