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. Strus2第一次课:dom4j解析xml文档

    xml文本标记语言: 常用于交换数据:独立于操作系统.编程语言数据存储:xml数据配置:灵活性强,可读性高可以使用css样式改变xml样式 xml解析技术:dom解析xml技术: sax解析xml技术 ...

  2. (原创)Xilinx的ISE生成模块ngc网表文件

    ISE中,右击“Synthesize”,选中“Process Properties”,将“Xilinx Specific Options:-iobuf”的对勾取消. 将取消模块的ioBuff,因为模块 ...

  3. ThinkPHP3.2中if判断条件是两个变量

    <select name="typeId"> <foreach name="typeInfo" item="v"> ...

  4. 如何编写高质量的Javascript代码

    1.避免全局变量,因为全局变量容易发生名称上的冲突,可维护性不好. a,使用命名空间 b,使用闭包 c,在函数内部使用var声明 2.编写可维护的代码 a.可读性 b.连续性 c.预见性 d.看起来是 ...

  5. Unity学习笔记

    『 知识点』 [射线] 射线检测碰撞 『游戏实战』 个例 [E]<愤怒的小鸟> 资源 免费Unity基础教程(中文电子书) [E] noobtus(Unity游戏教程)

  6. iOS 动画组

    其实早在一个多月以前就已经实现了动作组播放的功能,不过当时感觉好像没有什么难度并没有放在心上,今天突然要用到动画组,发现已经忘记了,所以又将原来的代码翻出来看了下.最后决定还是写下来,以备不时之需.动 ...

  7. 剔除eclipse的configuration目录[转]

    欢迎和大家交流技术相关问题: 邮箱: jiangxinnju@163.com 博客园地址: http://www.cnblogs.com/jiangxinnju GitHub地址: https://g ...

  8. List去重复(不是最简单,但绝对是最易理解)

    for (int i = 0; i < courselist.size(); i++) //外循环是循环的次数 { for (int j = courselist.size() - 1 ; j ...

  9. node.js基础 1之 HTTP知识填坑

    http使用流程: http协议 http 客户端发起请求,创建端口 http 服务器在端口监听客户端请求 http 服务器向客户端返回状态和内容 解析域名查找dns(资源)的过程: 1.chrome ...

  10. 删除Kafka的topic

    刚接触Kafka,开始认为删除一个topic只是运行一下Kafka-topic.sh的delete命令就行了,但是,事实却不是这样,会出现两种情况:(1) 如果topic没有使用过即没有传输过消息,可 ...