色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

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

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

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

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

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

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

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

主站蜘蛛池模板: 麻栗坡县| 保山市| 延安市| 英吉沙县| 玉山县| 兴安县| 孟村| 新闻| 信丰县| 建瓯市| 江陵县| 灌云县| 屯昌县| 万安县| 莫力| 九台市| 潼关县| 育儿| 滁州市| 兰坪| 依安县| 临潭县| 南城县| 银川市| 湾仔区| 水城县| 来宾市| 莒南县| 婺源县| 镶黄旗| 睢宁县| 山阴县| 日喀则市| 紫阳县| 河南省| 丹棱县| 抚顺市| 金川县| 石景山区| 茶陵县| 千阳县|