萬盛學電腦網

 萬盛學電腦網 >> 腳本專題 >> javascript >> 常見的原始JS選擇器使用方法總結

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

 常見的原始JS選擇器有getElementById,getElementsByName,getElementsByTagName,就使用上為大家總結下

常見的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 ~ 32毫秒,Chrome為23~ 26毫秒,  //safari4為19 ~ 20毫秒  function getElementsByClassName(oElm, strTagName, strClassName){  var arrElements = (strTagName == "*" && oElm.all)? 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 < arrElements.length; 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 < elsLen; 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");    alert(test.length);    }     
copyright © 萬盛學電腦網 all rights reserved