appendChild()方法遇到的问题
在使用appendChild()方法中遇到了一个问题:
下面的代码可以正常插入多个新元素
<input type="button" value="在后面插入新元素" id="btn6">
<div id="dv7">
<p>a</p>
<span>b</span>
<h3>c</h3>
</div>
<script>
var dv7 = document.getElementById("dv7");
document.getElementById("btn6").onclick = function(){
var newElement = document.createElement("input"); //创造一个新元素
newElement.type = "button";
newElement.value = "新元素"; dv7.appendChild(newElement); //在dv7的内部的最后插入新元素
};
</script>
下面的代码则无法实现
<input type="button" value="在后面插入新元素" id="btn6">
<div id="dv7">
<p>a</p>
<span>b</span>
<h3>c</h3>
</div>
<script>
var dv7 = document.getElementById("dv7");
var newElement = document.createElement("input"); //创造一个新元素
newElement.type = "button";
newElement.value = "新元素";
document.getElementById("btn6").onclick = function(){
dv7.appendChild(newElement); //在dv7的内部的最后插入新元素
};
</script>
查找资料发现一段话:如果文档树中已经存在了 newchild,它将从文档树中删除,然后重新插入它的新位置。
第一种方法中,每一次点击事件都会创造一个新元素,虽然名字相同但已经不是那一个元素了(点击事件结束newElement被释放),所以appendChild操作的新元素没有在DOM树中存在,可一多次插入新元素。
第二种方法中,创建newElement在点击事件之外,属于DOM树中的这个确定的新元素,多次触发点击事件,不能实现多次插入。
你可以使用 appendChild() 方法将一个元素移动到另外一个地方
例:下面的代码点击两个按钮,新元素位置会变化
<input type="button" value="在后面插入新元素" id="btn6">
<input type="button" value="改变新元素的位置" id="btn7">
<div id="dv7">
<p id="new">a</p>
<span>b</span>
<h3>c</h3>
</div>
<script>
var dv7 = document.getElementById("dv7");
var newElement = document.createElement("input"); //创造一个新元素
newElement.type = "button";
newElement.value = "新元素";
document.getElementById("btn6").onclick = function(){
dv7.appendChild(newElement); //在dv7的内部的最后插入新元素
};
document.getElementById("btn7").onclick = function(){
document.getElementById("new").appendChild(newElement); //在p标签内部的后面插入这个新元素
};
</script>
不仅对创建的新元素,DOM中原来存在的元素也可以用这种方法改变位置
appendChild()方法遇到的问题的更多相关文章
- 踩坑所引发出的appendChild方法的介绍
问题描述 最近在做项目时,遇到一个问题,当js生成一个组件后,会注入到页面的某个节点里显示.在组件内部进行了一次注入操作,在调用组件的外部js文件中也进行了一次注入操作,结果发现页面里只生成了一份组件 ...
- appendChild方法详解
方法:target.appendChild(ele); 执行该方法时,会发生两部操作: 1.将元素ele从原来的父元素中移除掉 2.将元素追加至新的目标元素中,并且保留元素的所有样式信息和事件... ...
- HTML DOM appendChild() 方法
<!DOCTYPE html> <html> <body> <ul id="myList"> <li>Coffee< ...
- PHP对XML添加节点之appendChild()方法讲解
问题如下:<b > <c>test</c> </b>我要在b节点里面添加一个子节点比如说加一个d节点,要实现成<b > <c>t ...
- C# 通过ImportNode AppendChild方法合并XmlDocument,XML转为DataTable
var doc1 = new XmlDocument(); var doc2 = new XmlDocument(); XmlNode root1 = doc1.DocumentElement; do ...
- js:插入节点appendChild insertBefore使用方法
首先 从定义来理解 这两个方法: appendChild() 方法:可向节点的子节点列表的末尾添加新的子节点.语法:appendChild(newchild) insertBefore() 方法:可在 ...
- JS中插入节点的方法appendChild和insertBefore的应用
1.appendChild() 方法:可以向节点的子节点列表的末尾添加新的子节点.比如:appendChild(newchild)括号里可以是创建的标签var newchild = document. ...
- JavaScript--元素对象方法setAttribute() 和appendChild()
appendChild() 方法可向节点的子节点列表的末尾添加新的子节点 setAttribute() 方法创建或改变某个新属性.如果指定属性已经存在,则只设置该值 <!DOCTYPE html ...
- JS(JavaScript)插入节点的方法appendChild与insertBefore
首先 从定义来理解 这两个方法: appendChild() 方法:可向节点的子节点列表的末尾添加新的子节点.语法:appendChild(newchild) insertBefore() 方法:可在 ...
随机推荐
- ios7自定义返回按钮后,右滑返回功能失效解决方法
-(void)viewWillAppear:(BOOL)animated{ [super viewWillAppear:animated]; //开启ios右滑返回 if ([ ...
- Java 中 Gson的使用
JSON 是一种文本形式的数据交换格式,它比XML更轻量.比二进制容易阅读和编写,调式也更加方便;解析和生成的方式很多,Java中最常用的类库有:JSON-Java.Gson.Jackson.Fast ...
- Jenkins部署报weblogic.deploy.api.tools.deployer.DeployerException: Java heap space
Jenkins部署报weblogic.deploy.api.tools.deployer.DeployerException: Java heap space异常 解决办法: 在MAVEN_OPTS中 ...
- js对象拷贝遇到的坑
问题:通过拷贝赋值后,所有的对象的name居然都是C test(){ let person = [{'name':'danny'}] let names = ['A','B','C'] let tem ...
- ABAP-FTP-执行
1.界面 2.程序 ZFID0004_FTP_EXEC 主程序: *&------------------------------------------------------------- ...
- 【FZSZ2017暑假提高组Day1】最大矩形
[问题描述] 现在有n个宽度为1的矩形按如下图(左边的)所示的方式排在了一起: 用肉眼容易看出,在左图内部面积最大的矩形如右图绿色部分所标注. 现在我们考虑将其中一些宽度为1的矩形取出,按照原顺序再次 ...
- 二十一、proxyDesign 代理模式
原理: 时序图: 代码清单: Printable public interface Printable { void setPrinterName(String name); String getPr ...
- oday获取系统最高权限的代码
import sys,sockettarget = sys.argv[1]shellcode = ("\x6a\x4f\x59\xd9\xee\xd9\x74\x24\xf4\x5b\x81 ...
- input只允许输入正整数
onkeyup="if(this.value.length==1){this.value=this.value.replace(/[^1-9]/g,'')}else{this.value=t ...
- php面试题五之nginx如何调用php和php-fpm的作用和工作原理
nginx如何调用php 采用nginx+php作为webserver的架构模式,在现如今运用相当广泛.然而第一步需要实现的是如何让nginx正确的调用php.由于nginx调用php并不是如同调用一 ...