1. 程式人生 > >原始JS選擇器使用方法總結

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

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

1.getElementById(),這是最常用的選擇器,通過id來定位,由於id是元素的唯一標識,所以不能定義重複的id,否則結果是很難控制的,這裡多說幾句,雖然css中有id選擇器,但是id選擇器通常情況下只是用於js,而類選擇器(class)用於css,這也算是不成文的規定吧,當然程式碼是靈活的,id選擇器在css中也有它的用武之地。

例:

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

2.getElementsByName(),這個選擇器是獲取name屬性為某個值的元素,一個文件中的 name 屬性可能不唯一(如 HTML 表單中的單選按鈕通常具有相同的 name 屬性),所以該方法返回的是所有匹配元素組成的陣列,而不是一個元素。

例:

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

3.getElementsByTagName()這個選擇器是獲取標籤名為某個值的元素,這個選擇器可以統一定義文件中某標籤的互動或樣式。

例:

var test=document.getElementsByTagName("xxx");//獲取文件中標籤為xxx的元素的節點,並賦值給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);
  }