一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

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

<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,感覺比較巧妙。

JavaScript技術javascript下查找父節點的簡單方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 天天做.天天爱.天天综合网 | 亚洲第一区二区快射影院 | 综合激情区视频一区视频二区 | 桃花综合久久久久久久久久网 | 国产全部理论片线观看 | 色婷婷九月 | 天天天操天天天干 | 午夜在线免费观看视频 | 桃花视频在线观看高清版mv | 欧美日韩一区二区在线观看视频 | 亚欧精品一区二区三区四区 | 成人综合激情 | 国产乱码一区二区三区四川人 | 亚州第一视频 | 日本久久综合 | 图片区小说区激情区偷拍区 | 国产原创中文视频 | 91福利国产在线观看网站 | 亚洲韩国日本欧美一区二区三区 | 久久夜色精品国产噜噜亚洲a | 亚洲精品无码专区在线播放 | 毛片久久| 春暖花开亚洲x8永久地址 | 日产精品一区二区免费 | 四虎影视国产精品一区二区 | www.黄色.con| 五月婷婷深爱 | 欧美激情图片小说 | 久本草在线中文字幕亚洲欧美 | 色老板最新 | 亚洲图片欧美文学小说激情 | 婷婷影院在线综合免费视频 | 久久一级视频 | 成年人在线观看视频 | 国产精品合集一区二区三区 | 国产成人综合一区精品 | 2022年国产精品久久久久 | 中文字幕一区二区三区精彩视频 | 91免费在线视频观看 | 91在线播放视频 | 美女三级在线 |