操作DOM
操作DOM DOM是什么 DOM:是树状的html document:是DOM的根节点 HTML文档被浏览器解析后就是一棵DOM树,要改变HTML的结构,可以通过JavaScript来操作DOM。 始终记住DOM是一个树形结构。 对DOM操作 操作一个DOM节点实际上就是这么几个操作: 更新:更新该DOM节点的内容,相当于更新了该DOM节点表示的HTML的内容; 遍历:遍历该DOM节点下的子节点,以便进行进一步操作; 添加:在该DOM节点下新增一个子节点,相当于动态增加了一个HTML节点; 删除:将该节点从HTML中删除,相当于删掉了该DOM节点的内容以及它包含的所有子节点。 查找节点 document.getElementById()//返回 document.getElementsByTagName() document.getElementsByClassName() document.querySelector(); document.querySelectorAll() //根据id找元素 var test = document.getElementById('test') var trs = document.getElementById('test-table').getElementsByTagName('tr'); // 获取节点test下的所有直属子节点: var cs = test.children; // 获取节点test下第一个、最后一个子节点: var first = test.firstElementChild; var last = test.lastElementChild; // 通过querySelector获取ID为q1的节点: var q1 = document.querySelector('#q1'); // 通过querySelectorAll获取q1节点内的符合条件的所有节点: var ps = q1.querySelectorAll('div.highlighted > p'); 更新DOM 更新DOM元素的内容 一种是修改innerHTML属性,这个方式非常强大,不但可以修改一个DOM节点的文本内容,还可以直接通过HTML片段修改DOM节点内部的子树: var p = document.getElementById('p-id'); //更新文本 p.innerHTML = 'ABC'; // <p id="p-id">ABC</p> //修改HTML的结构 p.innerHTML = 'ABC <span style="color:red">RED</span> XYZ'; // <p>...</p>的内部结构已修改 用innerHTML时要注意,是否需要写入HTML。如果写入的字符串是通过网络拿到了,要注意对字符编码来避免XSS攻击 第二种是修改innerText或textContent属性,这样可以自动对字符串进行HTML编码,保证无法设置任何HTML标签: var p = document.getElementById('p-id'); p.innerText = '<script>alert("Hi")</script>'; 两者的区别在于读取属性时,innerText不返回隐藏元素的文本,而textContent返回所有文本。另外注意IE<9不支持textContent。 插入DOM 如果这个DOM节点是空的,例如,<div></div>,那么,直接使用innerHTML = '<span>child</span>'就可以修改DOM节点的内容,相当于“插入”了新的DOM节点 有两个办法可以插入新的节点。 方法1:使用appendChild,把一个子节点添加到父节点的最后一个子节点 js = document.getElementById('js'), list = document.getElementById('list'); list.appendChild(js); 更多的时候我们会从零创建一个新的节点,然后插入到指定位置 var d = document.createElement('style'); d.setAttribute('type', 'text/css'); d.innerHTML = 'p { color: red }'; document.getElementsByTagName('head')[0].appendChild(d); insertBefore 如果我们要把子节点插入到指定的位置怎么办? 可以使用parentElement.insertBefore(newElement, referenceElement); 子节点会插入到referenceElement之前 删除DOM 父元素删除 这是常用的解决方案:找到您希望删除的子元素,然后使用其 parentNode 属性来找到父元素: var child=document.getElementById("p1"); child.parentNode.removeChild(child); 自己删掉 // 拿到待删除节点: var self = document.getElementById('to-be-removed'); // 拿到父节点: var parent = self.parentElement; // 删除: var removed = parent.removeChild(self); self.remove(); removed === self; // true 注意到删除后的节点虽然不在文档树中了,但其实它还在内存中,可以随时再次被添加到别的位置。 因此,删除多个节点时,要注意children属性时刻都在变化 复制节点 var self = document.getElementById('to-be-removed'); self .cloneNode(true); 修改节点属性7 节点对象.属性,只能访问节点固有的属性,访问不到自定义的属性 节点对象.getAttribute()能访问所有的属性,以后常用 div.getAttribute('msg') 节点对象.setAttribute() div.setAttribute("class","zhangss12112312312"); 节点对象.removeAttribute() div.removeAttribute("class"); DOM 定义了访问和操作 HTML 文档的标准 在 HTML DOM 中,所有事物都是节点。 HTML 文档中的所有内容都是节点: 文档节点:整个文档 元素节点:每个 HTML 元素 文本节点:HTML 元素内的文本 属性节点:每个 HTML 属性 注释是注释节点 节点树中的节点彼此拥有层级关系 父(parent)、子(child)和同胞(sibling) document就是html节点 为什么节点的第一个子节点不是属性节点而是文本节点 因为:属性节点藏在元素节点里面,所以你不能通过正常的方式获得到属性节点 索引就是下标,只是叫法不一样 parentNode,parentElement,childNodes,children区别 childNodes包含文本节点和元素节点 children仅包含元素节点 parentNode、parentElement是一样的 修改CSS DOM节点的style属性对应所有的CSS,可以直接获取或设置。 因为CSS允许font-size这样的名称,但它并非JavaScript有效的属性名,所以需要在JavaScript中改写为驼峰式命名fontSize: var p = document.getElementById('p-id'); // 设置CSS: p.style.color = '#ff0000'; p.style.fontSize = '20px'; p.style.paddingTop = '2em';