标签:文本 nts next elements 元素 col 自定义 other body
兼容性: 在IE8以下,会默认把name属性当做id来获取;document : 文档;上下问必须是documentget : 获取element : 元素By : 通过Id : ID名字;id 是唯一的;不能重复
var oBox = document.getElementById("box");// {className:"",style:{}} var oBox1 = oBox.getElementById("box1"); var a = document.getElementById("a"); console.log(a); console.log(oBox); console.log(typeof oBox);// "object" oBox.style.background = "red";
是一个类数组集合
var arr = oBox.getElementsByTagName("span");// "标签名"[{style:{}] arr[0].style.background = "red"; console.log(arr);
IE8及以下是不兼容的;通过class名字来获取元素;
var a = document.getElementsByClassName("box"); console.log(a.length); console.log(a);
在IE9及以下,会默认把id名是a的获取到;
var inputs = document.getElementsByName("a"); console.log(inputs);
console.log(document.documentElement); var htm = document.getElementsByTagName("html") console.log(htm);
console.log(document.body);获取当前浏览器可视窗口高度和宽度
var winW= document.documentElement.clientWidth || document.body.clientWidth; var winH = document.documentElement.clientHeight || document.body.clientHeight; console.log(winW); console.log(winH);
var divs = document.querySelector(".box"); // 如果是id名,前面需要加一个#;如果是class,要加一个. console.log(divs);
// querySelectorAll: 获取所有的元素; var divs = oBox.querySelectorAll("div") console.log(divs);
DOM的节点 : 四种类型的节点;
TYPE | nodeType | nodeName | nodeValue |
元素节点 | 1 | 大写的标签名 | null |
文本节点 | 3 | text | 文本内容 |
注释节点 | 8 | comment | 注释内容 |
document | 9 | document | null |
console.log(parent.childNodes);
parent.childNodes[1].style.width="100px";
firstElementChild : 第一个子元素节点; 在IE8及以下,是不兼容的;
lastElementChild : 最后一个子元素节点;在IE8及以下,是不兼容的;
console.log(parent.firstChild);
console.log(parent.firstElementChild);
previousElementSibling 封装 var last = document.getElementById("last"); // 获取上一个哥哥的元素节点; function getBrother(curEle) { var pre = curEle.previousSibling; while(pre){ if(pre.nodeType ===1){//不满足,说明不是一个元素; return pre; } pre = pre.previousSibling; } return pre; } getBrother(sec); getBrother(last)
nextElementSibling : 获取下一个元素弟弟节点;
console.log(sec.previousSibling);
console.log(sec.previousSibling); console.log(sec.parentNode.previousElementSibling); var body =document.body; document 没有父亲节点;如果没有获取结果就是null; console.log(body.parentNode.parentNode.parentNode);
oBox.innerHTML = "函数很重要";
var newDiv = document.createElement("div"); console.log(newDiv);
父级.appendChild(儿子) oBox.appendChild(newDiv); //Failed to execute ‘appendChild‘ on ‘Node‘: parameter 1 is not of type ‘Node‘ var div = document.getElementsByTagName("div")[1];
oBox.removeChild(div); var span = document.createElement("span")
父级.replaceChild(newChild,oldChild);
oBox.replaceChild(span,div);
父级.insertBefore(newChild,oldChild)
oBox.insertBefore(span,div);
// 参数: true: 深克隆,会当前元素以及子孙节点全部获取到 // false或不传 : 浅克隆,只会克隆当前元素节点; console.log(oBox.cloneNode(true)); console.log(oBox.cloneNode()); var a = document.getElementsByClassName("a")[0]; var b = a.cloneNode(true); oBox.appendChild(a);
//getAttribute 不能获取通过元素.属性 = 属性值这种方式新增的属性;可以获取行内直接设置的,还有通过setAttribute 来设置的属性; div.setAttribute("name","time"); div.index = 100; console.log(div.name);// undefined div.setAttribute("na","ti") 如果获取不到自定义行内属性,结果就是null; console.log(div.getAttribute("name")); console.log(div.getAttribute("index")); console.log(div.getAttribute("hh")); // 移出行内属性 div.removeAttribute("na");
标签:文本 nts next elements 元素 col 自定义 other body
原文地址:https://www.cnblogs.com/CCxi/p/9449347.html