您现在的位置是:群英 > 开发技术 > web开发
JS是怎么获取节点并进行兼容性封装的呢?
Admin发表于 2022-08-31 17:23:51423 次浏览
关于“JS是怎么获取节点并进行兼容性封装的呢?”的知识点有一些人不是很理解,对此小编给大家总结了相关内容,文中的内容简单清晰,易于学习与理解,具有一定的参考学习价值,希望能对大家有所帮助,接下来就跟随小编一起学习一下“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>



关于“JS是怎么获取节点并进行兼容性封装的呢?”的内容就介绍到这,感谢各位的阅读,相信大家对JS是怎么获取节点并进行兼容性封装的呢?已经有了进一步的了解。大家如果还想学习更多知识,欢迎关注群英网络,小编将为大家输出更多高质量的实用文章!

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

标签: JavaScript
相关信息推荐
2022-05-11 12:01:35 
摘要:这篇文章主要介绍了php微信小程序解包过程实例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2022-06-21 17:09:25 
摘要:本篇文章手把手带大家了解一个node实战,聊聊怎么基于node制作一个mycli命令行工具/脚手架,希望对大家有所帮助!
2022-01-29 15:09:32 
摘要:这篇文章我们来了解HTML中value和name属性的相关内容,下文主要介绍value和name属性的作用和使用,文中有详细的介绍,有需要的朋友可以参考,对新手学习Python会有帮助,接下来就跟随小编来一起学习一下吧!
云活动
推荐内容
热门关键词
热门信息
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部