javascript下查找父節(jié)點的簡單方法
更新時間:2007年08月13日 19:16:18 作者:
<div>
<a href="#">標(biāo)題</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==p){return i;}
if(n==document.documentElement){return -1;} //找不到目標(biāo)父節(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,感覺比較巧妙。
<a href="#">標(biāo)題</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==p){return i;}
if(n==document.documentElement){return -1;} //找不到目標(biāo)父節(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,感覺比較巧妙。
您可能感興趣的文章:
- JS 使用for循環(huán)遍歷子節(jié)點查找元素
- js查找父節(jié)點的簡單方法
- js查找節(jié)點的方法小結(jié)
- JS常見DOM節(jié)點操作示例【創(chuàng)建 ,插入,刪除,復(fù)制,查找】
- javascript基礎(chǔ)之查找元素的詳細(xì)介紹(訪問節(jié)點)
- js遍歷子節(jié)點子元素附屬性及方法
- javascript 節(jié)點遍歷函數(shù)
- JS獲取子節(jié)點、父節(jié)點和兄弟節(jié)點的方法實例總結(jié)
- javascript獲取網(wǎng)頁中指定節(jié)點的父節(jié)點、子節(jié)點的方法小結(jié)
- javascript得到XML某節(jié)點的子節(jié)點個數(shù)的腳本
- JS查找孩子節(jié)點簡單示例
相關(guān)文章
微信小程序中的店鋪評分組件及vue中用svg實現(xiàn)的評分顯示組件
這篇文章主要介紹了微信小程序之店鋪評分組件及vue中用svg實現(xiàn)的評分顯示組件,本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2018-11-11深入理解JavaScript系列(26):設(shè)計模式之構(gòu)造函數(shù)模式詳解
這篇文章主要介紹了深入理解JavaScript系列(26):設(shè)計模式之構(gòu)造函數(shù)模式詳解,本文講解了基本用法、構(gòu)造函數(shù)與原型、只能用new嗎?、強制使用new、原始包裝函數(shù)等內(nèi)容,需要的朋友可以參考下2015-03-03IE6中鏈接A的href為javascript協(xié)議時不在當(dāng)前頁面跳轉(zhuǎn)
IE6中當(dāng)鏈接A的href為javascript協(xié)議時不能在當(dāng)前頁面跳轉(zhuǎn),本例給出有效的解決方法,大家不妨參考下2014-06-06- 這篇文章主要介紹了JS實現(xiàn)左邊列表移到到右邊列表功能,實現(xiàn)功能主要是左邊的下拉框內(nèi)容添加到右邊的下拉框,支持多選移動,且同時將右邊的下拉框?qū)ο笠瞥?,需要的朋友可以參考?/div> 2018-03-03
微信小程序?qū)崿F(xiàn)全局狀態(tài)管理的方法整理
已知微信小程序中如果要做到全局狀態(tài)共享,常用的有四種方式,分別是globalData、本地緩存、mobx-miniprogram和westore,本文將帶大家看看mobx-miniprogram是如何實現(xiàn)的小程序的全局狀態(tài)管理,需要的可以收藏一下2023-06-06Javascript 檢測、添加、移除樣式(className)函數(shù)代碼
在前臺腳本中,我們經(jīng)常要操作頁面元素的樣式,比如標(biāo)簽頁切換時,將當(dāng)前標(biāo)簽加上一個樣式,當(dāng)切換到其他標(biāo)簽時,再將樣式還原,本文介紹的是直接添加和移除 className 的方法。2009-09-09獲取Javscript執(zhí)行函數(shù)名稱的方法
獲取Javscript執(zhí)行函數(shù)名稱的方法...2006-12-12最新評論