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

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

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

主站蜘蛛池模板: 五月婷婷丁香在线 | 精品久久久久久无码中文字幕 | 亚洲一区二区综合 | 国产偷久久 | 天天影院色 | 欧美综合网站 | 香蕉成人999视频 | 国内精品免费麻豆网站91麻豆 | 一区二区三区四区在线观看视频 | 国产色婷婷亚洲 | 亚洲人成依人成综合网 | 欧美午夜a级精美理论片 | 99视频免费播放 | 色幽幽| 国语自产精品视频 | 国产视频1| 正在播放亚洲一区 | 丁香五月好婷婷深深爱 | 精品在线91 | 天天五月天丁香婷婷深爱综合 | 国产成人高清 | 欧美性与交视频在线观看 | 久久伊人热精品老鸭窝 | 欧美日韩有码 | 91福利刘玥国产在线观看 | 91午夜视频| 四虎国产精品永久地址99新强 | 人人爱天天做夜夜爽2020麻豆 | 91免费精品视频 | 欧美激情视频在线观看免费 | 黄网站在线免费 | 国产成人啪精品视频免费网 | 欧美亚洲激情在线 | 婷婷伊人久久 | 国产成人在线视频免费观看 | 亚洲女人天堂 | 在线观看黄网站 | 99精品国产兔费观看66 | 手机看片www xiao2b cm | 日韩久久中文字幕 | 成人五月网 |