一、节点常用操作
document.createElement() 用来生成网页元素节点,参数为元素的标签名
document.createTextNode() 用来生成文本节点,参数为所要生成的文本节点的内容
node.appendChild() 接受一个节点对象作为参数,将其作为最后一个子节点,插入当前节点
node.hasChildNodes() 返回一个布尔值,表示当前节点是否有子节点
node.removeChild() 接受一个子节点作为参数,用于从当前节点移除该子节点
node.cloneNode() 用于克隆一个选中的节点。它接受一个布尔值作为参数,表示是否同时克隆子节点,默认是false,即不克隆子节点。注意: 不会克隆绑定到该元素上的事件
node.innerHTML 返回该元素包含的 HTML 代码。该属性可读写,常用来设置某个节点的内容;(不属于W3C DOM规范)
node.innerText 返回该元素包含的内容。该属性可读写
node.nextElementSibling 返回紧跟在当前节点后面的第一个同级Element节点,如果当前节点后面没有同级节点,则返回null
node.previousElementSibling 返回紧跟在当前节点前面的第一个同级Element节点,如果当前节点前面没有同级节点,则返回null
node.parentElement 返回当前节点的父级Element节点
node.childNodes 返回一个NodeList集合,成员包括当前节点的所有子节点(注意空格回车也算)
node.firstChild 返回树中节点的第一个子节点,如果节点是无子节点,则返回null
node.lastChild 返回该节点的最后一个子节点,如果该节点没有子节点则返回null
<div id="div" style="border:1px solid red;"> var p = document.createElement('p'); var pText = document.createTextNode('P标签内内容'); document.getElementById('div').appendChild(p);
二、节点属性
var div = document.querySelector('#div'); console.log(div.zhy); //undefined
属性操作的标准方法:
node.getAttribute() 返回当前元素节点的指定属性。如果指定属性不存在,则返回null
node.setAttribute() 为当前元素节点新增属性。如果同名属性已存在
node.hasAttribute() 返回一个布尔值,表示当前元素节点是否包含指定属性
node.removeAttribute() 从当前元素节点移除属性
var div = document.querySelector('#div'); //设置属性,有则修改,无则添加,可设置非标准属性 div.setAttribute('id','d'); div.setAttribute('zdy','zdy'); console.log(div.getAttribute('id')); //d console.log(div.getAttribute('zdy')); //zdy
三、css样式属性
节点对象.style.样式属性 方式只能获取行内css样式,而写在 style 标签内的样式表,无法获取和修改。
getComputedStyle() 接受一个节点对象,返回该节点对象最终样式信息的对象,所谓“最终样式信息”,指的是各种CSS规则叠加后的结果 注意: getComputedStyle() 是window对象下的方法,不是DOM对象
在具体使用的时候还有一些需要重点注意的细节:
1、名字需要改写,将横杠从CSS属性名中去除,然后将横杠后的第一个字母大写:
比如background-color写成backgroundColor
2、属性值都是字符串,设置时必须包括单位:
比如,divStyle.width的值不能写为100,而要写为100px
width: 200px; height: 200px; border: 1px solid red; document.getElementById('div').onclick = function(){ this.style.width = parseInt(getComputedStyle(div).width)+10+"px"; this.style.height = parseInt(getComputedStyle(div).height)+10+"px";
|