您好,登錄后才能下訂單哦!
這篇“JS怎么獲取節(jié)點并進行兼容性封裝”文章的知識點大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“JS怎么獲取節(jié)點并進行兼容性封裝”文章吧。
網(wǎng)頁內(nèi)容是由標簽組成的(不完全正確)
網(wǎng)頁的內(nèi)容是由節(jié)點組成的
元素節(jié)點 屬性節(jié)點 文本節(jié)點 注釋節(jié)點 文檔節(jié)點
節(jié)點三要素
節(jié)點類型 :nodeType
節(jié)點名稱 : nodeName
節(jié)點值 :nodeValue
節(jié)點類型(nodeType) 節(jié)點名稱( nodeName) 節(jié)點值(nodeValue) 元素節(jié)點 1 標簽名大寫 null屬性節(jié)點 2 屬性名 屬性值 文本節(jié)點 3 #text 文本 注釋節(jié)點 8 #comment 注釋內(nèi)容 文檔節(jié)點 9 #document null
獲取父節(jié)點 :子元素.parentNode
獲取子元素
<div id = "box"> <!--宮崎駿--> <div>千與千尋</div> <div id="box2">哈兒的移動城堡</div> 龍貓 <div>懸崖上的金魚姬</div> </div>
var box2 = document.getElementById("box2");console.log(box2.parentNode);
獲取的父節(jié)點一定是元素節(jié)點(只有元素才會有子節(jié)點)
添加子元素到頁面中(父元素中)父元素.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>
<div id = "box"> <!--宮崎駿--> <div>千與千尋</div> <div id="box2">哈兒的移動城堡</div> 龍貓 <div>懸崖上的金魚姬</div> </div>
獲取元素:
var box = document.getElementById("box");var box2 = document.getElementById("box2");
上一個節(jié)點
console.log(box2.previousSibling); // 文本節(jié)點
下一個節(jié)點
console.log(box2.nextSibling); // 文本節(jié)點
上一個元素
console.log(box2.previousElementSibling);
下一個元素
console.log(box2.nextElementSibling);
IE8不支持獲取兄弟元素的操作,執(zhí)行得到的undefined,而且 在IE8里面沒有任何替代方案
IE8要獲取兄弟元素 智能通過節(jié)點
@param ele :需要查找的目標封裝
@return node:返回的是一個元素節(jié)點
function getPreviousElement(ele) { // 能力檢測 if(ele.previousElementSibling) { // 谷歌火狐 return ele.previousElementSibling; } else { // IE8 // 獲取上一個節(jié)點 : null 元素 文本 注釋 var node = ele.previousSibling; // 循環(huán)次數(shù)不確定 // 1. node必須存在, 不是null, 2. node不是元素節(jié)點 while(node != null && node.nodeType != 1) { node = node.previousSibling } // node == null 或者 node.nodeType == 1 return node; } } console.log(getPreviousElement(li2));
獲取第一個子節(jié)點 :父元素.firstChild
獲取第一個子元素 :父元素.firstElementChild
var box = document.getElementById("box");console.log(box.firstChild);console.log(box.firstElementChild);
IE8無法執(zhí)行元素的操作
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);
獲取最后一個子節(jié)點 :父元素.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))
克隆節(jié)點 :元素.cloneNode(參數(shù))
參數(shù):
有參數(shù)時:
如果參數(shù)是true,表示深克?。?能夠克隆這個標簽以及標簽里面所有的內(nèi)容。
如果參數(shù)是false,表示淺克?。褐荒芸寺‘斍斑@個標簽,不會克隆這個標簽里面的內(nèi)容。
沒有參數(shù),默認是false。
<div id="box"> I'm a big box <h2>我是標題</h2> </div>
var box = document.getElementById("box");var Newbox = box.cloneNode(true)console.log(New);
克隆節(jié)點只會在內(nèi)存中克隆一份, 不會添加到頁面上 只能手動添加
克隆huibaid也克隆過去
為了保持頁面id的唯一性,需要修改克隆元素的id
Newbox.id = "Newbox"
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>關(guān)閉二維碼</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>
以上就是關(guān)于“JS怎么獲取節(jié)點并進行兼容性封裝”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。