DOM 含义: DOM 是文档对象模型(Document Object Model) 是一种基于浏览器编程的一套API 接口,我W3C 出台推荐的标准。其赋予了JS 操作节点的能力,当网页被加载时,浏览器就会创建页面的文档对象模型。
节点: 根据W3C的HTML DOM 标准,HTML 文档中的所有内容都是节点。
1. 整个文档是一个文档节点
2. 每个HTML元素是元素节点
3. HTML元素内的文本是文本节点
4.每个HTML属性都是属性节点
5.每个注释都是注释节点
所以HTML DOM 将HTML 文档视作树结构,这种结构被称为节点数。通过HTML DOM 节点树种的所有节点都可以通过JS进行访问。所有HTML 元素(节点)均可被修改、

一、 创建节点、追加节点
1.createElement(标签名)创建一个元素节点(具体的一个元素)。
2.appendChild(节点) 追加一个节点
3.createTextNode(节点文本内容)创建一个文本节点

var oDiv = document.createElement('div')  // 常见一个div元素,因为是document 对象的方法
var oDivText = document.createTextNode('666') // 创建一个文本节点内容是666 , 因为是document 对象的方法
oDiv.appendChild(oDivText) // 父级.appendChild(子节点); 在div元素中添加6666
document.body.appendChild(oDiv) // 父级.appendChild(子节点);document.body是指向<body> 元素
document.documentElement.appendChild(createNode) //父级.appendChild(子节点); document.documentElement 是指向html 元素
x
 
1
var oDiv = document.createElement('div')  // 常见一个div元素,因为是document 对象的方法
2
var oDivText = document.createTextNode('666') // 创建一个文本节点内容是666 , 因为是document 对象的方法
3
oDiv.appendChild(oDivText) // 父级.appendChild(子节点); 在div元素中添加6666
4
document.body.appendChild(oDiv) // 父级.appendChild(子节点);document.body是指向<body> 元素
5
document.documentElement.appendChild(createNode) //父级.appendChild(子节点); document.documentElement 是指向html 元素
二、插入节点
1.appendChild(节点)也是一种插入节点的方式,还可以添加已经存在的元素,会将其元素从原来的位置移动新的位置
2.insertBefore(a,b), 意思是a节点会插入b节点的前面
var oDiv = document.createElement("div");//创建一个div元素,因为是document对象的方法。
var oDiv1 = document.getElementById("div1");
document.body.insertBefore(oDiv,oDiv1);//在oDiv1节点前插入新创建的元素节点
ul.appendChild(ul.firstChild); //把ul的第一个元素节点移到ul子节点的末尾
1
 
1
var oDiv = document.createElement("div");//创建一个div元素,因为是document对象的方法。  
2
var oDiv1 = document.getElementById("div1");  
3
            document.body.insertBefore(oDiv,oDiv1);//在oDiv1节点前插入新创建的元素节点  
4
    ul.appendChild(ul.firstChild); //把ul的第一个元素节点移到ul子节点的末尾  
5

注: 在练习的时候,
注意以上2种写法的差别,下面一种换行的方式会导致,最后一个lastChild 是空格节点,所以必须保证同一行
详见附件方法

三、删除、移除节点
1、removeChild(节点) 删除一个节点,用于移除删除一个参数(节点)。其返回的被移除的节点,被移除的节点仍在文档中,只是文档中已没有其位置了。
var removeChild = document.body.removeChild(div1);//移除document对象的方法div1
1
 
1
var removeChild = document.body.removeChild(div1);//移除document对象的方法div1
四、替换节点
1、replaceChild(插入的节点,被替换的节点) ,用于替换节点,接受两个参数,第一参数是要插入的节点,第二个是要被替换的节点。返回的是被替换的节点。
var replaceChild= document.body.replaceChild(div1,div2); //将div1替换div2  
1
 
1
var replaceChild= document.body.replaceChild(div1,div2); //将div1替换div2  
五、查找节点
1、childNodes 包含文本节点和元素节点的子节点。
for (var i = 0; i < oList.childNodes.length; i++) {//oList是做的ul的对象。
//nodeType是节点的类型,利用nodeType来判断节点类型,再去控制子节点
//nodeType==1 是元素节点
//nodeType==3 是文本节点
if (oList.childNodes[i].nodeType == 1) {//查找到oList内的元素节点
console.log(oList.childNodes[i]);//在控制器日志中显示找到的元素节点
}
}
1
 
1
for (var i = 0; i < oList.childNodes.length; i++) {//oList是做的ul的对象。  
2
//nodeType是节点的类型,利用nodeType来判断节点类型,再去控制子节点  
3
//nodeType==1 是元素节点  
4
//nodeType==3 是文本节点  
5
    if (oList.childNodes[i].nodeType == 1) {//查找到oList内的元素节点  
6
        console.log(oList.childNodes[i]);//在控制器日志中显示找到的元素节点  
7
    }  
8
}  
2、A、children也可以获取子节点,而且兼容各种浏览器。包括IE6-8
B、parentNode:获取父节点
var oList = document.getElementById('list');//oList是做的ul的对象
var oChild=document.getElementById('child');//oChild是做的ul中的一个li的对象
//通过子节点查找父节点//parentNode:获取父节点
console.log(oChild.parentNode);//在控制器日志中显示父节点
console.log(oList.children);//在控制器日志中显示oList子节点
console.log(children.length)//子节点的个数
1
 
1
var oList = document.getElementById('list');//oList是做的ul的对象  
2
var oChild=document.getElementById('child');//oChild是做的ul中的一个li的对象  
3
//通过子节点查找父节点//parentNode:获取父节点  
4
console.log(oChild.parentNode);//在控制器日志中显示父节点  
5
console.log(oList.children);//在控制器日志中显示oList子节点  
6
console.log(children.length)//子节点的个数  
3、A、firstChild ; firstElementChild查找第一个子节点。此存在浏览器兼容问题:firstChild是IE兼容,firstElementChild是非IE兼容。
<span style="white-space:pre">      </span>//查找第一个子节点的封装函数
<span style="white-space:pre"> </span>function firstChild(ele) {
<span style="white-space:pre"> </span>if (ele.firstElementChild) {<span style="font-family: Arial, Helvetica, sans-serif;">//如果该条件是true则在该浏览器(IE或非IE)中兼容</span>
<span style="white-space:pre"> </span> return ele.firstElementChild;
<span style="white-space:pre"> </span>} else {
<span style="white-space:pre"> </span> return ele.firstChild;
<span style="white-space:pre"> </span>}
<span style="white-space:pre"> </span>}
<span style="white-space:pre"> </span>firstChild(oList).style.background = 'red';//将获得的节点的背景变成红色
1
 
1
<span style="white-space:pre">      </span>//查找第一个子节点的封装函数  
2
<span style="white-space:pre">      </span>function firstChild(ele) {  
3
    <span style="white-space:pre">      </span>if (ele.firstElementChild) {<span style="font-family: Arial, Helvetica, sans-serif;">//如果该条件是true则在该浏览器(IE或非IE)中兼容</span>  
4
    <span style="white-space:pre">      </span> return ele.firstElementChild;  
5
    <span style="white-space:pre">      </span>} else {  
6
    <span style="white-space:pre">      </span> return ele.firstChild;  
7
    <span style="white-space:pre">      </span>}  
8
<span style="white-space:pre">      </span>}  
9
<span style="white-space:pre">      </span>firstChild(oList).style.background = 'red';//将获得的节点的背景变成红色  
B、lastChild ; lastElementChild查找最后一个子节点。此存在浏览器兼容问题:lastChild 是IE兼容,lastElementChild是非IE兼容。
<span style="white-space:pre">      </span>//查找最后一个子节点的封装函数
<span style="white-space:pre"> </span>function lastChild(ele) {
<span style="white-space:pre"> </span>if (ele.lastElementChild) {<span style="font-family: Arial, Helvetica, sans-serif;">//如果该条件是true则在该浏览器(IE或非IE)中兼容</span>
<span style="white-space:pre"> </span> return ele.lastElementChild;
<span style="white-space:pre"> </span>} else {
<span style="white-space:pre"> </span> return ele.lastChild;
<span style="white-space:pre"> </span>}
<span style="white-space:pre"> </span>}
<span style="white-space:pre"> </span>lastChild(oList).style.background = 'red';//将获得的节点的背景变成红色
1
 
1
<span style="white-space:pre">      </span>//查找最后一个子节点的封装函数  
2
<span style="white-space:pre">      </span>function lastChild(ele) {  
3
    <span style="white-space:pre">      </span>if (ele.lastElementChild) {<span style="font-family: Arial, Helvetica, sans-serif;">//如果该条件是true则在该浏览器(IE或非IE)中兼容</span>  
4
    <span style="white-space:pre">      </span> return ele.lastElementChild;  
5
    <span style="white-space:pre">      </span>} else {  
6
    <span style="white-space:pre">      </span> return ele.lastChild;  
7
    <span style="white-space:pre">      </span>}  
8
<span style="white-space:pre">      </span>}  
9
<span style="white-space:pre">      </span>lastChild(oList).style.background = 'red';//将获得的节点的背景变成红色  
C、nextSibling ; nextElementSibling查找下一个兄弟节点。也是存在兼容性问题。
<span style="white-space:pre">      </span>//查找下一个兄弟节点的封装函数
<span style="white-space:pre"> </span>function nextSibling(ele) {
<span style="white-space:pre"> </span>if (ele.nextElementSibling) {
<span style="white-space:pre"> </span> return ele.nextElementSibling;
<span style="white-space:pre"> </span>} else {
<span style="white-space:pre"> </span> return ele.nextSibling;
<span style="white-space:pre"> </span>}
<span style="white-space:pre"> </span>}
<span style="white-space:pre"> </span>nextSibling(oMid).style.background = 'red';
1
 
1
<span style="white-space:pre">      </span>//查找下一个兄弟节点的封装函数  
2
<span style="white-space:pre">      </span>function nextSibling(ele) {  
3
    <span style="white-space:pre">      </span>if (ele.nextElementSibling) {  
4
    <span style="white-space:pre">      </span> return ele.nextElementSibling;  
5
    <span style="white-space:pre">      </span>} else {  
6
    <span style="white-space:pre">      </span> return ele.nextSibling;  
7
        <span style="white-space:pre">      </span>}  
8
    <span style="white-space:pre">      </span>}  
9
<span style="white-space:pre">      </span>nextSibling(oMid).style.background = 'red';  
D、previousSibling ; previousElementSibling查找上一个兄弟节点。也是存在兼容性问题。
<span style="white-space:pre">      </span>//查找上一个兄弟节点的封装函数
<span style="white-space:pre"> </span>function previousSibling(ele) {
<span style="white-space:pre"> </span>if (ele.nextElementSibling) {
<span style="white-space:pre"> </span> return ele.previousElementSibling;
<span style="white-space:pre"> </span>} else {
<span style="white-space:pre"> </span> return ele.previousSibling;
<span style="white-space:pre"> </span> }
<span style="white-space:pre"> </span>}
<span style="white-space:pre"> </span>previousSibling(oMid).style.background = 'red';
1
 
1
<span style="white-space:pre">      </span>//查找上一个兄弟节点的封装函数  
2
<span style="white-space:pre">      </span>function previousSibling(ele) {  
3
    <span style="white-space:pre">      </span>if (ele.nextElementSibling) {  
4
    <span style="white-space:pre">      </span> return ele.previousElementSibling;  
5
    <span style="white-space:pre">      </span>} else {  
6
    <span style="white-space:pre">      </span> return ele.previousSibling;  
7
    <span style="white-space:pre">      </span>     }  
8
    <span style="white-space:pre">      </span>}  
9
<span style="white-space:pre">      </span>previousSibling(oMid).style.background = 'red';  
转载至:http://blog.csdn.net/torrex/article/details/54376633

附件列表

javasript 的DOM 节点操作:创建,插入,删除,复制以及查找节点的更多相关文章

  1. jQuery 节点操作(创建 插入 删除 复制 替换 包裹)

    一,创建元素节点: 第1个步骤可以使用jQuery的工厂函数$()来完成,格式如下: $(html); $(html)方法会根据传入的HTML标记字符串,创建一个DOM对象,并将这个DOM对象包装成一 ...

  2. ORACLE 11gR2 RAC添加删除(正常及强制)节点操作步骤(删除篇)

    ORACLE 11gR2 RAC添加删除(正常及强制)节点操作步骤(删除篇) 本文主要转载 [  http://www.cnxdug.org/?p=2511 ] 有部分细节自己实验添加,再此谢谢前辈. ...

  3. js的DOM节点操作:创建 ,插入,删除,复制,查找节点

    DOM含义:DOM是文档对象模型(Document Object Model,是基于浏览器编程的一套API接口,是W3C出台的推荐标准.其赋予了JS操作节点的能力.当网页被加载时,浏览器就会创建页面的 ...

  4. 节点操作-创建并添加&删除节点&替换&克隆节点

    <head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" ...

  5. MySQL进阶11--DDL数据库定义语言--库创建/修改/删除--表的创建/修改/删除/复制

    /*进阶 11 DDL 数据库定义语言 库和表的管理 一:库的管理:创建/修改/删除 二:表的管理:创建/修改/删除 创建: CREATE DATABASE [IF NOT EXISTS] 库名; 修 ...

  6. [剑指Offer]18-题目一:删除链表的节点 题目二:删除链表中重复节点

    题目一 题目 O(1)时间复杂度删除给定链表节点. 题解 用待删除节点后一个节点的值覆盖待删除节点值,更新链接关系. 注意链表只有一个节点:删除尾结点:删除头节点的处理. 代码 class ListN ...

  7. js节点的创建添加删除

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  8. 链表的C++实现——创建-插入-删除-输出-清空

    注:学习了数据结构与算法分析后,对链表进行了C++实现,参考博文:http://www.cnblogs.com/tao560532/articles/2199280.html 环境:VS2013 // ...

  9. [PHP] 数据结构-链表创建-插入-删除-查找的PHP实现

    链表获取元素1.声明结点p指向链表第一个结点,j初始化1开始2.j<i,p指向下一结点,因为此时p是指向的p的next,因此不需要等于3.如果到末尾了,p还为null,就是没有查找到 插入元素1 ...

随机推荐

  1. ios 7.1企业证书无线安装

    ios升级到7.1时,企业证书http服务器发布无线安装不能使用,需要使用https服务器. 测试了几种方式 1.测试时自签名https证书测试无效,提示不能连接到服务器 2.使用dropbox共享连 ...

  2. C语言中的undefined behavior

    参考: http://www.cnblogs.com/aoaoblogs/archive/2010/08/31/1813982.html

  3. MinDos--操作系统

    MinDos--操作系统 总结 : 本次实现的是功能是为 (1)自行定义系统提示符 (2)自定义命令集(8-10个) (3)用户输入HELP以查找命令的帮助 (4)列出命令的功能,区分内部还是外部命令 ...

  4. ie8开发人员工具无法使用,按f12任务栏里出现任务,但是窗体不弹出

    楼主解决了么,刚出现你这样的问题,找了N久,终于解决了,他娘的,偏方啊任务栏不是出现那个箭头么,点击后没反应是吧在缩略图上点右键-最大化,然后就出来了,ctrl+p反正是可以出来调试模式 神人哪,IE ...

  5. SpringCloud之服务注册-eureka

    类似于DUBBO 的zookeeper, SpringCloud本身提供一套服务注册中心--eureka 与zookeeper的区别在于 1:zookeeper本身就是一个应用,安装即可用:eurek ...

  6. 微信小程序进行地图导航使用地图功能

    之前我写过的文章当中,提过小程序的打包大小.所以特地去下载一个区域的地图的这种方法,是不存在的. 我用的导航主要使用的是应用外的导航,这篇文章可能对于非常熟悉小程序的小伙伴来说就是小case,所以只适 ...

  7. 现在有很多第三方的SDK来做直播,那么我们改选择哪一种?

    现在大部分的都会借助第三方的直播技术,这样可以保证直播的质量,趣拍直播就很不错,SDK很好集成,芒果直播也在用.下面来分析一下趣拍直播的一些心得. 如何快速搭建一个完整的手机直播系统 在这个直播如火如 ...

  8. (博弈 sg入门)kiki's game -- hdu -- 2147

    链接: http://acm.hdu.edu.cn/showproblem.php?pid=2147 题意: 在一个n*m的棋盘上,从  (1,m),即右上角开始向左下角走. 下棋者只能往左边(lef ...

  9. TCP的几个状态(SYN/FIN/ACK/PSH/RST)

    在TCP层,有个FLAGS字段,这个字段有以下几个标识:SYN, FIN, ACK, PSH, RST, URG. 其中,对于我们日常的分析有用的就是前面的五个字段. 含义: SYN 表示建立连接, ...

  10. 点滴笔记(二):利用JS对象把值传到后台

    记得以前刚写asp.net 从前台往后台传值 都是var data=A,B,C,D,E; 循环添加用逗号隔开 后台还要被测试测出只输入,就错了 哈哈..后来用✈◆类似的符号隔开 不是长久之计... 现 ...