1.DOM操作

  DOM是Document Object Model的缩写,即文档对象模型,是基于文档编程的一套API接口。

  使用JavaScript操作DOM时分为三个方面:

  1.1:DOM Core(核心): 针对任何结构化文档的标准模型

  1.2:HTML-DOM:针对 HTML 文档的标准模型

  1.3:XML DOM - 针对 XML 文档的标准模型

2.节点和节点关系

  • 整个文档是一个文档节点
  • 每个HTML标签是一个元素节点
  • 包含在HTML元素中的文本是文本节点
  • 每个HTML属性是一个属性节点
  • 注释属于注释节点

3.访问节点

  3.1使用getElement系列方法访问指定节点

  • getElementById():返回按id属性查找的第一个对象的引用
  • getElementByName():返回带有指定名称name查找的对象的集合,由于一个文档中可能会有多个同名节点,因此返回的是元素数组
  • getElementByTagName():返回带有指定标签名称TagName查找的对象的集合,返回元素数组

  3.2根据层次关系访问节点

  • parentNode:                            返回节点的父节点
  • childNodes:             返回子节点集合,childNodes[i]
  • firstChild:                                返回节点的第一个子节点
  • lastChild:                           返回节点的最后一个子节点
  • nextSibling:                  下一个节点
  • previousSibing:                       上一个节点

  3.3解决浏览器兼容问题:
  firstElementChild 返回节点的第一个子节点,最普遍的用法是访问该元素的文本节点
  lastElementChild 返回节点的最后一个子节点
  nextElementSibling 下一个节点
  previousElementSibling 上一个节点

  例如:oNext = 节点.nextElementSibling || 节点.nextSibling

4.节点信息

   常用属性:

  • nodeName(节点名称)
  • nodeValue(节点值)
  • nodeType(节点类型)

   操作节点的属性

  • getAttribute("属性名"):用来获取属性的值
  • setAttribute("属性名","属性值"):用来设置属性的值  

   创建和插入节点:

 

  • createElement( tagName) 创建一个标签名为tagName的新元素节点
  • A.appendChild( B) 把B节点追加至A节点的末尾
  • insertBefore( A,B ) 把A节点插入到B节点之前
  • cloneNode(deep) 复制某个指定的节点

  删除和替换节点:

  • removeChild( node) 删除指定的节点
  • replaceChild( newNode, oldNode)属性attr 用其他的节点替换指定的节点