DOM操作 ——如何添加、移除、移动、复制、创建和查找节点等。

(1)创建新节点

  createDocumentFragment() //创建一个DOM片段

  createElement() //创建一个具体的元素

  createTextNode() //创建一个文本节点

(2)添加、移除、替换、插入

(1)创建新节点

  createDocumentFragment()    //创建一个DOM片段

  createElement()   //创建一个具体的元素

  createTextNode()   //创建一个文本节点

(2)添加、移除、替换、插入

  appendChild()

  removeChild()

  replaceChild()

  insertBefore()

(3)查找

  getElementsByTagName()    //通过标签名称

  getElementsByName()    //通过元素的Name属性的值

  getElementById()    //通过元素Id,唯一性

  本节要用到的html例子

  <ul id="myList">

    <li>项目一</li>

    <li>项目二</li>

    <li>项目三</li>

  </ul>

1.创建元素节点document.createElement() 方法 用于创建元素,接受一个参数,即要创建元素的标签名,返回创建的元素节点

  var div = document.createElement("div");  //创建一个div元素

  div.id = "myDiv";        //设置div的id

  div.className = "box";    //设置div的class

  创建元素后还要把元素添加到文档树中

2.添加元素节点appendChild() 方法 用于向childNodes列表的末尾添加一个节点,返回要添加的元素节点

  var ul = document.getElementById("myList");    //获得ul

  var li = document.createElement("li");         //创建li

  li.innerHTML = "项目四";                    //向li内添加文本

  ul.appendChild(li);                //把li 添加到ul子节点的末尾

  添加后:

  <ul id="myList">

    <li>项目一</li>

    <li>项目二</li>

    <li>项目三</li>

    <li>项目四</li>

  </ul>

appendChild() 方法还可以添加已经存在的元素,会将元素从原来的位置移到新的位置

  var ul = document.getElementById("myList");    //获得ul

  ul.appendChild(ul.firstChild);            //把ul的第一个元素节点移到ul子节点的末尾

  运行后(IE):

  <ul id="myList">

    <li>项目二</li>

    <li>项目三</li>

    <li>项目一</li>

  </ul>

insertBefore() 方法 ,如果不是在末尾插入节点,而是想放在特定的位置上,用这个方法,该方法接受2个参数,第一个是要插入的节点,第二个是参照节点,返回要添加的元素节点

eg-1:

  var ul = document.getElementById("myList");    //获得ul

  var li = document.createElement("li");         //创建li

  li.innerHTML= "项目四";                    //向li内添加文本

  ul.insertBefore(li,ul.firstChild);        //把li添加到ul的第一个子节点前

  添加后:

  <ul id="myList">

    <li>项目四</li>

    <li>项目一</li>

    <li>项目二</li>

    <li>项目三</li>

  </ul>

eg-2:

    var ul = document.getElementById("myList");    //获得ul

    var li = document.createElement("li");         //创建li

    li.innerHTML= "项目四";               //向li内添加文本

    ul.insertBefore(li,ul.lastChild);        //把li添加到ul的子节点末尾

  添加后:

  <ul id="myList">

    <li>项目一</li>

    <li>项目二</li>

    <li>项目三</li>

    <li>项目四</li>

  </ul>

eg-3:

  var ul = document.getElementById("myList");    //获得ul

  var li = document.createElement("li");         //创建li

  li.innerHTML= "项目四";                    //向li内添加文本

  var lis = ul.getElementsByTagName("li")   //获取ul中所有li的集合

  ul.insertBefore(li,lis[1]);            //把li添加到ul中的第二个li节点前

  添加后:

  <ul id="myList">

    <li>项目一</li>

    <li>项目四</li>

    <li>项目二</li>

    <li>项目三</li>

  </ul>

 3.移除元素节点

 removeChild() 方法 ,用于移除节点,接受一个参数,即要移除的节点,返回被移除的节点,注意被移除的节点仍然在文档中,不过文档中已没有其位置了

  var ul = document.getElementById("myList");            //获得ul

  var fromFirstChild = ul.removeChild(ul.firstChild);    //移除ul第一个子节点

  var ul = document.getElementById("myList");    //获得ul

  var lis = ul.getElementsByTagName("li")        //获取ul中所有li的集合

  ul.removeChild(lis[0]);                  //移除第一个li,与上面不同,要考虑浏览器之间的差异

4.替换元素节点replaceChild() 方法 ,用于替换节点,接受两个参数,第一参数是要插入的节点,第二个是要替换的节点,返回被替换的节点

  var ul = document.getElementById("myList");            //获得ul

  var fromFirstChild = ul.replaceChild(ul.firstChild);    //替换ul第一个子节点

  var ul = document.getElementById("myList");    //获得ul;

  var li = document.createElement("li");         //创建li

  li.innerHTML= "项目四";                    //向li内添加文本

  var lis = ul.getElementsByTagName("li")        //获取ul中所有li的集合

  var returnNode = ul.replaceChild(li,lis[1]);   //用创建的li替换原来的第二个li

5.复制节点cloneNode() 方法,用于复制节点, 接受一个布尔值参数, true 表示深复制(复制节点及其所有子节点), false 表示浅复制(复制节点本身,不复制子节点)

  var ul = document.getElementById("myList");    //获得ul

  var deepList = ul.cloneNode(true);            //深复制

  var shallowList = ul.cloneNode(false);        //浅复制

DOM操作 ——如何添加、移除、移动、复制、创建和查找节点等。的更多相关文章

  1. JS中的DOM操作怎样添加、移除、移动、复制、创建和查找节点

    DOM操作怎样添加.移除.移动.复制.创建和查找节点? (1)创建新节点 createDocumentFragment() //创建一个DOM片段 createElement() //创建一个具体的元 ...

  2. 手写面试编程题- 数组去重 深拷贝 获取文本节点 设置奇数偶数背景色 JS中检测变量为string类型的方法 第6题闭包 将两个数组合并为一个数组 怎样添加、移除、移动、复制、创建和查找节点? 继承 对一个数组实现随机排序 让元素水平 垂直居中的三种方式 通过jQuery的extend方法实现深拷贝

    第1题==>实现数组去重 通过 new Set(数组名) // var arr = [12, 12, 3, 4, 5, 4, 5, 6, 6]; // var newarr1 = new Set ...

  3. DOM操作——JavaScript怎样添加、移除、移动、复制、创建和查找节点

    (1). 创建新节点 createDocumentFragment() // 创建一个DOM片段 createElement() // 创建一个具体的元素 createTextNode() // 创建 ...

  4. DOM操作怎样添加、移除、移动、复制。创建和查找节点?

    (1)创建新节点 createDocumentFragment() //创建一个DOM片段 createElement() //创建一个具体的元素 createTextNode() //创建一个文本节 ...

  5. [简洁]JavaScript中添加、移除、移动、复制、创建和查找节点元素

    查找: document.getElementsByTagName通过标签名获取元素,不论有多少个都返回元素集合. document.getElementsByClassName通过类名获取元素,同上 ...

  6. jQuery系列 第七章 jQuery框架DOM操作

    第七章 jQuery框架的选择器 jQuery框架继承和优化了JavaScript访问DOM对象的特性,我们使用jQuery框架提供的api可以更加方便的操作DOM对象. 7.1 创建DOM节点 使用 ...

  7. 理解js的DOM操作

    1.DOM结构——两个节点之间可能存在哪些关系以及如何在节点之间任意移动.document.documentElement     返回文档的根节点<html> document.body ...

  8. js,jQuery和DOM操作的总结(一)

    废话不说,直接上图 一 js的基本操作 (1)js 的六种数据类型 var n4;//六种数据类型用typeof来确定类型,Null类型的用typeof是不行的,这个是特殊 alert(typeof ...

  9. 页面性能优化和高频dom操作

    一.DOM操作影响页面性能的核心问题 通过js操作DOM的代价很高,影响页面性能的主要问题有如下几点: 访问和修改DOM元素 修改DOM元素的样式,导致重绘或重排 通过对DOM元素的事件处理,完成与用 ...

随机推荐

  1. (原创)Windows系统后安装ubuntu,无法选择启动ubuntu。

    继Window系统之后,安装Ubuntu系统. 问题:启动没有Grub的ubuntu启动项. 查看:/boot/grub/中只有txt和env,内容空白,grub没有设置好. 修复: sudo fdi ...

  2. 慕课网__css_ float

  3. Android TabHost使用

    TabHost是Android中自带的选项卡控件,效果图如下: 主布局文件 <RelativeLayout xmlns:android="http://schemas.android. ...

  4. 转载ali面

    引言 首先声明,不要再问LZ谁是林萧,林萧就是某著名程序员小说的主角名字. 写这篇文章的目的其实很简单,算是对之前LZ一篇文章的补充和完善. 之前LZ写过一篇<回答阿里社招面试如何准备,顺便谈谈 ...

  5. HTML <a> download 属性,点击链接来下载图片

    Html5里面的 标签的 Download 属性可以设置一个值来规定下载文件的名称.所允许的值没有限制,浏览器将自动检测正确的文件扩展名并添加到文件 (.img, .pdf, .txt, .html, ...

  6. jQuery 移动端ajax请求列表数据,实现点击翻页效果(还有手势往下滑动翻页)。

    1 首先是html部分 <div class="content"> <div class="list"></div>  // ...

  7. hadoop中遇到的一些问题

    1.验证词统计程序.----无法加载本地库 出现错误: WARN util.NativeCodeLoader: Unable to load native-hadoop library for you ...

  8. ubuntu 跟xshell的问题

    有2个分析: 1:是windos的防火墙没有关闭 2:是虚拟机没有安装sshd服务器 ubuntu在CLI界面下输入:dpkg -l |grep ssh 因为是我安装过的sshd server   要 ...

  9. 效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中【附源代码下载】) 转

    效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中[附源代码下载])    本文目录: (一)背景 (二)数据库数据导入到Excel的方法比较   ...

  10. 239. Sliding Window Maximum *HARD* -- 滑动窗口的最大值

    Given an array nums, there is a sliding window of size k which is moving from the very left of the a ...