国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

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

2024-05-06 16:03:53
字體:
來源:轉載
供稿:網友
常見的原始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, "http://-");
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);
  }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 易门县| 沅陵县| 阳山县| 镇沅| 湾仔区| 河津市| 泗洪县| 宜春市| 陈巴尔虎旗| 泰州市| 兴安盟| 新晃| 远安县| 池州市| 嘉祥县| 双峰县| 礼泉县| 滨州市| 彰化市| 康乐县| 东阿县| 大宁县| 呼和浩特市| 迁安市| 鹤壁市| 霍邱县| 故城县| 香河县| 邢台市| 泸州市| 顺义区| 山西省| 晴隆县| 沈丘县| 广东省| 安泽县| 宁武县| 重庆市| 正阳县| 台南县| 文登市|