javascript下尋找父節點的簡單方法

來源:互聯網
上載者:User

<div>
<a href="#">標題</a>
<ul id="demo">
<li><a href="#" onclick="selectThisItem(this)">項目一</a></li>
<ul>
<li><a href="#" onclick="selectThisItem(this)">子類一</a></li>
<li><a href="#" onclick="selectThisItem(this)">子類二</a></li>
</ul>
<li><a href="#" onclick="selectThisItem(this)">項目一</a></li>
<li><a href="#" onclick="selectThisItem(this)">項目</a></li>
</ul>
</div>

上面的代碼中,在點擊項目或子類時,因為觸發的事件一樣,參數也一樣,能區別使用者點擊的到底是“項目x”還是“子類x”,除了this.innerHTML來判斷它們的內在文字外,還可以根據它們在以<ul id="demo">元素為根節點的xml文檔中的縱向位置(節點深度)來區別,比如“項目一”在<ul id="demo">中的節點深度是2,“子類一”的節點深度是4.

計算節點深度在排除遞迴方法後,找到了一個更為簡單的方法:

function parentIndexOf(node,parent){
if(node==parent){return 0;}
for (var i=0,n=node; n=n.parentNode; i++){
if(n==p){return i;}
if(n==document.documentElement){return -1;} //找不到目標父節點,防止死迴圈
}
}

函數的傳回值是索引數字,如果入口節點與尋找的父節點相同(即同一個元素),傳回值為0,向上迴圈找到父節點後返迴向上尋找的節點級數,如果向上尋找,到了整個頁面的根節點,比如是<html>,還找不到,就返回-1,並結束迴圈。

傳回值與String對象內建的indexOf方法相似。函數的關鍵是for的第二個參數n=n.parentNode,感覺比較巧妙。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.