媒介
這两天寫的一個小功用,須要獵取HTMLCollection指定對象的索引,深入研究以後才發明本身學問域的盲區,在這裏也寫出來紀錄一下,願望和我存在一樣疑心的朋儕能夠一同討論一下。
HTMLCollection是什麼:
- 它是HTML DOM對象的一個接口,這個接口包含了獵取到的DOM元素鳩合,返回的範例是Object。
- 它很像數組,又不是數組,假如你想運用數組的一些要領操縱這個鳩合,那末不好意思。
- 它是實時更新的,當文檔中的DOM變化是,它是會隨之變化的。
- 屬性:HTMLCollection.length,返回鳩合當中子元素的數量。
它有自帶的要領
1.HTMLCollection.item(index),參數為下標,返回詳細的節點。 2.HTMLCollection.namedItem(value),參數為字符串,返回詳細的節點。
什麼時候我們會獵取到HTMLCollection對象?
簡樸,我們獵取dom元素就會獵取到的。<ul> <li>1</li> <li>2</li> <li>3</li> <li>4</li> <li>5</li> <li>6</li> <li>7</li> </ul> <script type="text/javascript"> var lis= document.getElementsByTagName("li"); console.log(lis); console.log(typeof lis); </script>
運轉結果:
3.怎樣獵取HTMLCollection對象的下標?
經由過程HTMLCollection.item(index)和HTMLCollection.namedItem(value)獵取到的都是DOM節點,那怎樣獵取到指定節點的下標呢,這個官方是沒有供應響應的要領的,下面我們經由過程一個例子完成一下。
需求:ul列表中點擊子級li,打印li對應的下標。
說下我的初始主意,既然HTMLCollection是個對象,那末indexof這類操縱明顯很瞎,既然不能運用數組的要領掌握它,那我就把它編程數組,然後就用for輪迴balabala....寫了一大堆,將它轉為數組,再寫點擊事宜查找下標,結果完成是完成了,可特么太費力了,看看這代碼量
var lis= document.getElementsByTagName("li");
var ul = document.getElementsByTagName("ul")[0];
//=======================看下面==========================
var newArr = [];
for(var i in lis){
newArr.push(lis[i])
}
//=======================看下面==========================
//事宜託付綁定事宜
ul.onclick = function(e){
var even = e||event;
var target = even.target;
if(target.nodeName.toLowerCase() == "li"){
//=======================看下面==========================
var index = newArr.indexOf(target)
return index;
//=======================看下面==========================
}
}
emmmm……兩次輪迴,結果完成
如今換種要領,直接操縱HTMLCollection對象
var arr= document.getElementsByTagName("li");
var ul = document.getElementsByTagName("ul")[0];
ul.onclick = function(e){
var even = e||event;
var target = even.target;
if(target.nodeName.toLowerCase() == "li"){
//=======================看下面==========================
for(var k in arr){
if(arr[k] == target)return k;
}
//=======================看上面==========================
}
}
good~~~ 一次輪迴就搞定,這是我現在想到的最合理的要領,對