首頁 >web前端 >js教程 >常見的原始JS選擇器使用方法總結_javascript技巧

常見的原始JS選擇器使用方法總結_javascript技巧

WBOY
WBOY原創
2016-05-16 16:52:581212瀏覽

常見的getElementById,getElementsByName,getElementsByTagName。但外國人不滿意這些API,於是搞出了getElementsByClassName,後來一點點又出現了jQuery選擇器,這裡只說原始js選擇。

1.getElementById

這是最常用的選擇器,透過id來定位:

例:

var test=document.getElementById(" test").value;//取得文件中id為test的元素的值,並賦值給test變臉

2.getElementsByName

例:

var test= document.getElementByName("test");//取得文件中name為test的元素的節點,並賦值給test變量,此時test變數是數組

3.getElementsByTagName

例:

var test=document.getElementsByTagName("test");//取得文件中class為test的元素的節點,並賦值為test,此時test變數是數組,這個選擇器在IE5,6,7,8中無法使用

4.getElementsByClassName

這個選擇器在js的API中是找不到的,想要使用必須自己定義方法,通常的原理為先使用getElementsByTagName("*")取出文件中所有元素,然後進行遍歷,使用正規表示式找出符合的元素放入陣列返回。網路上有很多程式設計師實現了這個選擇器,下面舉兩例:

(1)The Ultimate getElementsByClassName方案,作者為Robert Nyman,05年實現,可見老外許多東西在很早以前就走得很遠了。

複製程式碼 程式碼如下:

//三個參數都是必要的,找出一>

//三參數網頁中5007個類名為「cell」的元素,IE8歷時1828 ~ 1844毫秒,
//IE6為4610 ~ 6109毫秒,FF3.5為46 ~ 48毫秒,opera10為31 ~ 3225,Chrome為毫秒23~ 26毫秒,
//safari4為19 ~ 20毫秒
function getElementsByClassName(oElm, strTagName, strClassName){
var arrElements = (strTagName == "*" & oElm. all :
oElm.getElementsByTagName(strTagName);
var arrReturnElements = new Array();
strClassName = strClassName.replace(/-/g, "\-");
var oRegExp = new RegExp("(^|\s)" strClassName "(\s|$)");
var oElement;
for(var i=0; i oElement = arrElements[i];
if(oRegExp.test(oElement.className)){
arrReturnElements.push(oElement);
}
}
return (arrReturnElements)
}

(2)由Dustin Diaz(《JavaScript Design Patterns》的作者)提供,但相容性不如上面的,不支援IE5。 複製程式碼
程式碼如下:


/網頁後兩參數中5007個類名為「cell」的元素,IE8歷時78毫秒,IE6歷時125~171毫秒
//FF3.5為42 ~ 48毫秒,opera10為31 毫秒,Chrome為22~ 25毫秒,safari4為18 ~ 19毫秒
var getElementsByClass = function(searchClass,node,tag) {
var classElements = new Array();
if ( node == null )
node = document; >if ( tag == null )
tag = '*';
var els = node.getElementsByTagName(tag);
var elsLen = els.length;
var pattern = new RegExp(" (^|\s)" searchClass "(\s|$)");
for (i = 0, j = 0; i if ( pattern.test(els[i ].className) ) {
classElements[j] = els[i];
j ;
}
}
return classElements;
}


------------------------------------------------- -------------------------------------------------- -------------------------------------------------- ---

註:this可以表示目前元素的節點。

-------------------------------------------- -------------------------------------------------- -------------------------------------------------- --------

以下是配合事件等知識點的一些常用的使用方法: 程式碼如下:

//提交id為test的表單

document.getElementById("test").submit();

//將id為test元素的邊框設為2個像素,實體,紅色

document.getElementById("test").style.border="2px solid red";

//滑鼠移動或移出id為test的元素,改變其背景色

function test(){
document.getElementById("test").onmouseover=function(){document.getElementById("test2").style.backgroundColor="red"} ;
document.getElementById("test").onmouseout=function(){document.getElementById("test2").style.backgroundColor="blue"};
}

///彈出文件中name為test的元素的個數

function test()
  {
  var test=document.getElementsByName("test");
  alerttest. 🎜>  }

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn