四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

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下查找父節點的簡單方法,轉載需保留來源!

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

主站蜘蛛池模板: 鬼迷心窍1994| cctv16直播| 高慧君| 暗夜尖叫1988美国版高清观看| 守株待兔评课| 羞羞的视频| 12123交强险查询入口| 伊莎贝拉·罗西里尼| 雾里看花电视剧剧情介绍| 婚前协议电视剧演员表| 霜雪千年简谱| 羞羞短视频| 杨晨足球| 蕾切尔·薇兹| 《起风了》数字简谱| 小绿人| 音乐僵尸| 西藏藏语卫视| 那些花儿吉他谱原版| 乔治桑| 林繁男| 四级词汇电子版| 女同性激烈床戏舌吻戏| 想想办法吧爸爸| 密杀名单| 金珉奎怎么读| 农村gaygayxxx| 亲吻姐姐ova| 圣般若摄颂| 铁拳男人 电影| xiuren秀人网站入口| 妻子的秘密免费看全集| 性视频网站在线| 蓝莓之夜 电影| 周星驰的全部电影免费观看| 花落花开电影| 有氧运动有哪些项目| 王艺霏| 女神宿舍管理君动漫| douying| 外出韩版|