本文主要给大家介绍js如何获取节点及兼容性封装,希望对需要的朋友有所帮助!
节点网页内容是由标签组成的(不完全正确)
网页的内容是由节点组成的
元素节点 属性节点 文本节点 注释节点 文档节点
节点三要素
节点类型 :nodetype节点名称 : nodename节点值 :nodevalue 节点类型(nodetype) 节点名称( nodename) 节点值(nodevalue)元素节点 1 标签名大写 null属性节点 2 属性名 属性值文本节点 3 #text 文本注释节点 8 #comment 注释内容文档节点 9 #document null
获取父节点获取父节点 :子元素.parentnode
获取子元素
<div id = "box"> <!--宫崎骏--> <div>千与千寻</div> <div id="box2">哈儿的移动城堡</div> 龙猫 <div>悬崖上的金鱼姬</div> </div>
var box2 = document.getelementbyid("box2");console.log(box2.parentnode);
获取的父节点一定是元素节点(只有元素才会有子节点)
添加子元素到页面中(父元素中)父元素.appendchild(子元素)
获取所有子节点 <div id="box" style="width: 100px; height: 100px;"> <div id="box1" style="background-color: lightblue;">千与千寻</div> <div id="box2">哈尔的移动城堡</div> </div> <script type="text/javascript"> var box = document.getelementbyid("box") console.log(box.chilnodes); </script>
1.兄弟元素和兄弟节点获取兄弟节点<div id = "box"> <!--宫崎骏--> <div>千与千寻</div> <div id="box2">哈儿的移动城堡</div> 龙猫 <div>悬崖上的金鱼姬</div> </div>
获取元素:
var box = document.getelementbyid("box");var box2 = document.getelementbyid("box2");
上一个节点
console.log(box2.previoussibling); // 文本节点
下一个节点
console.log(box2.nextsibling); // 文本节点
获取兄弟元素上一个元素
console.log(box2.previouselementsibling);
下一个元素
console.log(box2.nextelementsibling);
ie8不支持获取兄弟元素的操作,执行得到的undefined,而且 在ie8里面没有任何替代方案
ie8要获取兄弟元素 智能通过节点
获取上一个兄弟元素的封装@param ele :需要查找的目标封装
@return node:返回的是一个元素节点
function getpreviouselement(ele) { // 能力检测 if(ele.previouselementsibling) { // 谷歌火狐 return ele.previouselementsibling; } else { // ie8 // 获取上一个节点 : null 元素 文本 注释 var node = ele.previoussibling; // 循环次数不确定 // 1. node必须存在, 不是null, 2. node不是元素节点 while(node != null && node.nodetype != 1) { node = node.previoussibling } // node == null 或者 node.nodetype == 1 return node; } } console.log(getpreviouselement(li2));
2.获取第一个子节点和子元素获取第一个节点和子元素获取第一个子节点 :父元素.firstchild
获取第一个子元素 :父元素.firstelementchild
var box = document.getelementbyid("box");console.log(box.firstchild);console.log(box.firstelementchild);
ie8无法执行元素的操作
获取第一个子元素的兼容性封装 function getfirstelementchild(ele) { if (ele.firstelementchild != undefined) { return ele.firstelementchild; } else { var nodefirst = ele.firstchild; while (nodefirst && nodefirst.nodetype == 1) { nodefirst = nodefirst.nextsibling; } return nodefirst; } } console.log(ul.firstelementchild);
3.获取最后一个子节点和子元素获取最后一个子节点和子元素获取最后一个子节点 :父元素.lastchild
获取最后一个子元素 :父元素.lastelementchild
var box = document.getelementbyid("box");console.log(box.lastchild);console.log(box.lastelementchild);
获取最后一个子元素的兼容性封装 function firstelement(ele) { if (ele.firstelementchild) {//谷歌和火狐 return ele.firstelementchild; } else {//ie8 var node = ele.firstchild; while (node != null && node.nodetype != 1) { node = node.nextsibling; } return node; } } console.log(firstelement(ul))
4.克隆节点克隆节点 :元素.clonenode(参数)
参数:
有参数时:
如果参数是true,表示深克隆: 能够克隆这个标签以及标签里面所有的内容。
如果参数是false,表示浅克隆:只能克隆当前这个标签,不会克隆这个标签里面的内容。
没有参数,默认是false。
<div id="box"> i'm a big box <h1>我是标题</h1> </div>
var box = document.getelementbyid("box");var newbox = box.clonenode(true)console.log(new);
克隆节点只会在内存中克隆一份, 不会添加到页面上 只能手动添加
克隆huibaid也克隆过去
为了保持页面id的唯一性,需要修改克隆元素的id
newbox.id = "newbox"
淘宝案例,隐藏二维码<!doctype html><html> <head> <meta charset="utf-8" /> <title>关闭二维码</title> <style type="text/css"> #box{ width: 94px; height: 92px; margin: 30px auto; position: relative; } #x{ width: 14px; height: 14px; line-height: 14px; border: 1px solid #d9d9d9; color: #d6d6d6; text-align: center; position: absolute; top: 0; left: -15px; } #img{ width: 76px; height: 90px; background-image: url(img/erweima.png); } </style> </head> <body> <div id="box"> <div id="x">x</div> <div id="img"></div> </div> <script type="text/javascript"> var x = document.getelementbyid("x") x.onclick = function(){ this.parentnode.style.display = 'none'; } </script> </body></html>
相关推荐:【javascript视频教程】
以上就是解析js如何获取节点并进行兼容性封装的详细内容。