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. hdu4449Building Design(三维凸包+平面旋转)

    链接 看了几小时也没看懂代码表示的何意..无奈下来问问考研舍友. 还是考研舍友比较靠谱,分分钟解决了我的疑问. 可能三维的东西在纸面上真的不好表示,网上没有形象的题解,只有简单"明了&quo ...

  2. PHP JSON

  3. 01.JavaScript 面向对象精要--原始类型和引用类型

    一.什么是类型 JavaScript 虽然没有类的概念.但依然存在两种类型:原始类型和应用类型. 原始类型保存为简单的数据值,引用类型则保存为对象,其本质是指向内存位置 的引用.也就是说:原始值被直接 ...

  4. python的string用法

    s.strip().lstrip().rstrip(',') S.lower() #小写 S.upper() #大写 S.swapcase() #大小写互换 S.capitalize() #首字母大写 ...

  5. 原生javascript实现省市区三级联动

    腾讯IP分享计划(http://ip.qq.com/)有个现成的三级联动功能,查看源码后发现可以直接使用其单独的JS文件(http://ip.qq.com/js/geo.js). 分析后发现自己需要写 ...

  6. 动态加载zTree,用key属性设置url链接、icon图标等

      setting 举例 1. 设置 zTree 显示节点时,将 treeNode 的 xUrl 属性当做节点链接的目标 URL var setting = { data: { key: { url: ...

  7. Android开发--Adapter的应用

    1.简介 Adapter的作用是为GridView,ListView等界面控件与数据之间搭建桥梁,每当列表里的每一项显示到页面时,都会调用到Adapter的getView方法 返回一个View.在An ...

  8. [IOS 开发] TableView、多个TableViewCell、自定义Cell、Cell上画画(故事板+代码方式)

    第一步: //UserTableViewCell.h这里定义第一种Cell #import <UIKit/UIKit.h> @interface UserTableViewCell : U ...

  9. Android6.0获取权限

    照着<第一行代码>打代码,然并卵,感叹技术进步的神速.最后提醒一点:IT类的书籍一定要注意出版时间!出版时间!出版时间!重要的事情说三遍 问题出在android6.0的权限获取问题上,以前 ...

  10. Linux安装脚本需要交互之如何实现自动安装

    Linux中shell脚本运行时经常需要进行交互,比如安装软件的过程中对license声明的确认,需要输入yes,回车之类的确认信息.这个在自动化安装的时候就会是个问题. 通常对于这个问题比较灵活的解 ...