天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

js查找父節點的簡單方法

<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==parent){return i;}
        if(n==document.documentElement){return -1;} //找不到目標父節點,防止死循環
    }
}
函數的返回值是索引數字,如果入口節點與查找的父節點相同(即同一個元素),返回值為0,向上循環找到父節點后返回向上查找的節點級數,如果向上查找,到了整個頁面的根節點,比如是<html>,還找不到,就返回-1,并結束循環。

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

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

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

主站蜘蛛池模板: 亚洲欧洲日韩视频在钱 | 日本高清免费一本在线观看 | 久久只精品99品免费久 | 9国产露脸精品国产麻豆 | 天美传媒色情原创精品 | 亚洲国产精品热久久 | 双性大乳浪受噗呲噗呲h总 双性被疯狂灌满精NP | 办公室里呻吟的丰满老师电影 | 精品亚洲麻豆1区2区3区 | 儿媳妇完整版视频播放免费观看 | 久久永久视频 | 久久久91精品国产一区二区 | 最近高清日本免费 | 色综合99久久久国产AV | 123超碰在线视频 | 亚洲国产无线码在线观看 | 女人高潮被爽到呻吟在线观看 | 欧美多人群p刺激交换电影 欧美多毛的大隂道 | 天堂Av亚洲欧美日韩国产综合 | 中文字幕日本在线mv视频精品 | 窝窝色资源站 | 国产在线观看黄 | 毛片手机在线 | 国产亚洲视频中文字幕 | 97成人精品视频在线播放 | 无人在线观看免费高清视频播放 | 忘忧草在线社区WWW日本直播 | 亚洲 综合 欧美在线视频 | 亚洲日韩精品AV中文字幕 | 久久精品一区二区三区资源网 | 国产精品v欧美精品v日韩 | 国产电影午夜成年免费视频 | 在线国内自拍精品视频 | 国产小视频在线高清播放 | 嗯好大好猛皇上好深用力 | 特级做A爰片毛片免费69 | 国产AV一区二区三区日韩 | 国产精品欧美一区二区在线看 | 国产在线播放KKK | 色哟哟网站入口在线观看视频 | 麻豆国产人妻欲求不满 |