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

js查找父節(jié)點(diǎn)的簡單方法

<div>
        <a href="#">標(biāo)題</a>
        <ul id="demo">
            <li><a href="#" onclick="selectThisItem(this)">項(xiàng)目一</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)">項(xiàng)目一</a></li>
            <li><a href="#" onclick="selectThisItem(this)">項(xiàng)目</a></li>
        </ul>
</div>
上面的代碼中,在點(diǎn)擊項(xiàng)目或子類時(shí),因?yàn)橛|發(fā)的事件一樣,參數(shù)也一樣,能區(qū)別用戶點(diǎn)擊的到底是“項(xiàng)目x”還是“子類x”,除了this.innerHTML來判斷它們的內(nèi)在文字外,還可以根據(jù)它們在以<ul id="demo">元素為根節(jié)點(diǎn)的xml文檔中的縱向位置(節(jié)點(diǎn)深度)來區(qū)別,比如“項(xiàng)目一”在<ul id="demo">中的節(jié)點(diǎn)深度是2,“子類一”的節(jié)點(diǎn)深度是4.

計(jì)算節(jié)點(diǎn)深度在排除遞歸方法后,找到了一個(gè)更為簡單的方法:

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;} //找不到目標(biāo)父節(jié)點(diǎn),防止死循環(huán)
    }
}
函數(shù)的返回值是索引數(shù)字,如果入口節(jié)點(diǎn)與查找的父節(jié)點(diǎn)相同(即同一個(gè)元素),返回值為0,向上循環(huán)找到父節(jié)點(diǎn)后返回向上查找的節(jié)點(diǎn)級數(shù),如果向上查找,到了整個(gè)頁面的根節(jié)點(diǎn),比如是<html>,還找不到,就返回-1,并結(jié)束循環(huán)。

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

JavaScript技術(shù)js查找父節(jié)點(diǎn)的簡單方法,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产高清自拍 | 97av视频| 亚洲一区二区三区久久精品 | 亚洲第一区视频在线观看 | 香蕉成人啪国产精品视频综合网 | 美女扒开屁股让男人桶视频网站 | 69免费在线视频 | 国产精品播放 | 91精品综合国产在线观看 | 四虎精品免费永久在线 | 五月丁香六月综合缴清无码 | 青草碰人人澡人人澡 | 天天艹天天 | 五月深爱婷婷 | 国产成人一区二区 | 狠狠色噜噜狠狠狠97影音先锋 | 国产一级不卡毛片 | 九九操视频| 成人综合在线观看 | 色婷婷在线视频 | 91久久国产精品视频 | 亚洲乱码一二三四区国产 | 激情六月婷婷 | 91不卡| 色视频网址 | 久久夜色精品国产噜噜 | www.黄色免费 | 久久精品国产亚洲网站 | 亚洲第一区视频 | 天天操天天干天天插 | 成人激情免费视频 | 日本一区二区三区四区五区 | 午夜视频在线观看www中文 | 天堂成人在线观看 | 思思99re热 | 欧洲一卡2卡三卡4卡免费观看 | 国产成人精品自线拍 | 久久99国产一区二区三区 | 国产亚洲精品91 | 中文字幕三级 | 五月激情五月婷婷 |