设为首页 加入收藏

TOP

JavaScript常见DOM节点操作实例(一)
2018-12-23 22:08:19 】 浏览:233
Tags:JavaScript 常见 DOM 节点 操作 实例

java script常见DOM节点操作示例,创建 ,插入,删除,复制,查找。


java script获取dom节点的方法


获取上一个节点: previousElementSibling
获取下一个节点: nextElementSibling
获取父节点: parentElement
获取子节点: children


JS常见DOM节点操作示例【创建 ,插入,删除,复制,查找】
节点:根据 W3C 的 HTML DOM 标准,HTML 文档中的所有内容都是节点:


整个文档时一个文档节点。
每个HTML元素是元素节点。
HTML元素内的文本是文本节点。
每个HTML属性是属性节点。
每个注释是注释节点。


所以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元素中添加“666”
 document.body.appendChild(oDiv);//父级.appendChild(子节点);;document.body是指向<body>元素
 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、removeChild(节点) 删除一个节点,用于移除删除一个参数(节点)。其返回的被移除的节点,被移除的节点仍在文档中,只是文档中已没有其位置了。
 var removeChild = document.body.removeChild(div1);//移除document对象的方法div1


四、替换节点
1、replaceChild(插入的节点,被替换的节点) ,用于替换节点,接受两个参数,第一参数是要插入的节点,第二个是要被替换的节点。返回的是被替换的节点。


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]);//在控制器日志中显示找到的元素节点
  }
 }


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)//子节点的个数


3、
A、firstChild ; firstElementChild查找第一个子节点。此存在浏览器兼容问题:firstChild是IE兼容,firstElementChild是非IE兼容。
 //查找第一个子节点的封装函数
 function firstChild(ele) {
  if (ele.firstElementChild) {//如果该条件是true则在该浏览器(IE或非IE)中兼容
    return ele.firstElementChild;
  } else {
    return ele.firstChild;
  }
 }
 firstChild(oList).style.background = 'red';//将获得的节点的背景变成红色


B、lastChild ; lastElementChild查找最后一个子节点。此存在浏览器兼容问题:lastChild 是IE兼容,lastElementChild是非IE兼容。
 //查找最后一个子节点的封装函数
 function lastChild(ele) {
  if (ele.lastElementChild) {//如果该条件是true则在该浏览器(IE或非IE)中兼容
    return ele.lastElementChild;
  } else {
    return ele.lastChild;
  }
 }
 lastC

首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇JSON转化成对象或者数组 使用jQue.. 下一篇深入理解JavaScript闭包

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目