国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

js查找父節點的簡單方法

2019-11-21 01:42:32
字體:
來源:轉載
供稿:網友
<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,感覺比較巧妙。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 洛川县| 徐水县| 崇州市| 自贡市| 会泽县| 云阳县| 绍兴县| 大庆市| 桑植县| 开平市| 西乡县| 辉县市| 原阳县| 沽源县| 二连浩特市| 财经| 绿春县| 新蔡县| 普陀区| 通渭县| 沅江市| 康定县| 盐池县| 苏尼特左旗| 西城区| 大丰市| 革吉县| 双江| 临猗县| 顺义区| 徐水县| 苍梧县| 鹿邑县| 沁源县| 都兰县| 宁德市| 渝北区| 丽江市| 澄江县| 张家界市| 靖宇县|