DOM独立于具体的编程语言,通常通过javascript访问DOM,一些属性和方法以及对它们的用户列举如下:
一、用于处理文档的DOM元素的属性
nodeValue : 指定表示元素值的读/写属性
childNodes : 返回当前元素所有子元素的数组
parentNode : 返回元素的父节点
firstChild : 返回当前元素的第一个下级子元素
lastChild : 返回当前元素的最后一个元素
nextSibling: 返回紧跟在当前元素后面的元素
previousSibling : 返回紧邻当前元素之前的元素
二、用于遍历文档的DOM元素的方法
getElementById(id) : 获取有指定唯一ID属性值文档中的元素
getElementsByTagName(name) : 返回当前元素中有指定标记名的子元素的数组
hasChildNodes() : 返回一个布尔值,指示元素是否有子元素
getAtrribute(name) : 返回元素的属性值,属性由name指定
三、动态创建内容时所用的DOM属性和方法
document.createElement(tagName)
文档对象上的createElement方法可以创建由tagName指定的元素。如果以串div作为方法参数,就会生成一个div元素
document.createTextNode(text)
文档对象的createTextNode方法会创建一个包含静态文本的节点
<element>.appendChild(childNode)
appendChild方法将指定的节点增加到当前元素的子节点列表(作为一个新的子节点)。例如:可以增加一个option元素作为select元素的子节点
<element>.getAttribute(name)
<element>.setAttribute(name,value)
这些方法分别获得和设置元素中name属性的值
<element>.insertBefore(newNode,targetNode)
这个方法将节点newNode作为当前元素的子节点插到targetNode元素前面
<element>.removeAttribute(name)
从元素中删除属性name
<element>.removeChild(childNode)
从元素中删除子元素childNode
<element>.replaceChild(newNode,oldNode)
将节点oldNode替换为节点newNode
<element>.hasChildnodes()
返回一个布尔值,指示元素是否有子元素