常見的原始JS選擇器使用方法總結(jié)
更新時(shí)間:2014年04月09日 17:00:18 作者:
常見的原始JS選擇器有g(shù)etElementById,getElementsByName,getElementsByTagName,就使用上為大家總結(jié)下
常見的getElementById,getElementsByName,getElementsByTagName。但外國人不滿意這些API,于是搞出了getElementsByClassName,后來一點(diǎn)點(diǎn)又出現(xiàn)了jQuery選擇器,這里只說原始js選擇。
1.getElementById
這是最常用的選擇器,通過id來定位:
例:
var test=document.getElementById("test").value;//獲取文檔中id為test的元素的值,并賦值給test變臉
2.getElementsByName
例:
var test=document.getElementByName("test");//獲取文檔中name為test的元素的節(jié)點(diǎn),并賦值給test變量,此時(shí)test變量是一個(gè)數(shù)組
3.getElementsByTagName
例:
var test=document.getElementsByTagName("test");//獲取文檔中class為test的元素的節(jié)點(diǎn),并賦值給test,此時(shí)test變量是一個(gè)數(shù)組 ,這個(gè)選擇器在IE5,6,7,8中無法使用
4.getElementsByClassName
這個(gè)選擇器在js的API中是找不到的,想要使用必須自己定義方法,通常的原理為先使用getElementsByTagName("*")取出文檔中所有元素,然后進(jìn)行遍歷,使用正則表達(dá)式找出匹配的元素放入一個(gè)數(shù)組返回。網(wǎng)上有很多程序員實(shí)現(xiàn)了這個(gè)選擇器,下面舉兩例:
(1)The Ultimate getElementsByClassName方案,作者為Robert Nyman,05年實(shí)現(xiàn),可見老外許多東西在很早以前就走得很遠(yuǎn)了。
//三個(gè)參數(shù)都是必需的,查找一網(wǎng)頁中5007個(gè)類名為“cell”的元素,IE8歷時(shí)1828 ~ 1844毫秒,
//IE6為4610 ~ 6109毫秒,F(xiàn)F3.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。
//后兩參數(shù)是可靠的,查找一網(wǎng)頁中5007個(gè)類名為“cell”的元素,IE8歷時(shí)78毫秒,IE6歷時(shí)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可以表示當(dāng)前元素的節(jié)點(diǎn)。
--------------------------------------------------------------------------------------------------------------------------------------------------------
下面是配合事件等知識(shí)點(diǎn)的一些常用的使用方法:
//提交id為test的表單
document.getElementById("test").submit();
//將id為test元素的邊框設(shè)置為2個(gè)像素,實(shí)體,紅色
document.getElementById("test").style.border="2px solid red";
//鼠標(biāo)移動(dòng)或移出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的元素的個(gè)數(shù)
function test()
{
var test=document.getElementsByName("test");
alert(test.length);
}
1.getElementById
這是最常用的選擇器,通過id來定位:
例:
var test=document.getElementById("test").value;//獲取文檔中id為test的元素的值,并賦值給test變臉
2.getElementsByName
例:
var test=document.getElementByName("test");//獲取文檔中name為test的元素的節(jié)點(diǎn),并賦值給test變量,此時(shí)test變量是一個(gè)數(shù)組
3.getElementsByTagName
例:
var test=document.getElementsByTagName("test");//獲取文檔中class為test的元素的節(jié)點(diǎn),并賦值給test,此時(shí)test變量是一個(gè)數(shù)組 ,這個(gè)選擇器在IE5,6,7,8中無法使用
4.getElementsByClassName
這個(gè)選擇器在js的API中是找不到的,想要使用必須自己定義方法,通常的原理為先使用getElementsByTagName("*")取出文檔中所有元素,然后進(jìn)行遍歷,使用正則表達(dá)式找出匹配的元素放入一個(gè)數(shù)組返回。網(wǎng)上有很多程序員實(shí)現(xiàn)了這個(gè)選擇器,下面舉兩例:
(1)The Ultimate getElementsByClassName方案,作者為Robert Nyman,05年實(shí)現(xiàn),可見老外許多東西在很早以前就走得很遠(yuǎn)了。
復(fù)制代碼 代碼如下:
//三個(gè)參數(shù)都是必需的,查找一網(wǎng)頁中5007個(gè)類名為“cell”的元素,IE8歷時(shí)1828 ~ 1844毫秒,
//IE6為4610 ~ 6109毫秒,F(xiàn)F3.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。
復(fù)制代碼 代碼如下:
//后兩參數(shù)是可靠的,查找一網(wǎng)頁中5007個(gè)類名為“cell”的元素,IE8歷時(shí)78毫秒,IE6歷時(shí)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可以表示當(dāng)前元素的節(jié)點(diǎn)。
--------------------------------------------------------------------------------------------------------------------------------------------------------
下面是配合事件等知識(shí)點(diǎn)的一些常用的使用方法:
復(fù)制代碼 代碼如下:
//提交id為test的表單
document.getElementById("test").submit();
//將id為test元素的邊框設(shè)置為2個(gè)像素,實(shí)體,紅色
document.getElementById("test").style.border="2px solid red";
//鼠標(biāo)移動(dòng)或移出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的元素的個(gè)數(shù)
function test()
{
var test=document.getElementsByName("test");
alert(test.length);
}
相關(guān)文章
getElementByIdx_x js自定義getElementById函數(shù)
最近看JS代碼,發(fā)現(xiàn)不少人問getElementByIdx_x是什么函數(shù),其實(shí)就是個(gè)getElementById自定義函數(shù)2012-01-01EasyUI閃屏EasyUI頁面加載提示(原理+代碼+效果圖)
這篇文章主要介紹了EasyUI閃屏EasyUI頁面加載提示(原理+代碼+效果圖)的相關(guān)資料,需要的朋友可以參考下2016-02-02js 采用delete實(shí)現(xiàn)繼承示例代碼
這篇文章主要介紹了js如何采用delete實(shí)現(xiàn)所謂的繼承,下面有個(gè)不錯(cuò)的示例,大家可以參考下2014-05-05javascript 動(dòng)態(tài)table添加colspan\rowspan 參數(shù)的方法
動(dòng)態(tài)的給某個(gè)表對(duì)象添加列屬性和行屬性,采用obj.setAttribute("rowspan",n)(即rowspan=n)不能生效。2009-07-07dedecms頁面如何獲取會(huì)員狀態(tài)的實(shí)例代碼
下面小編就為大家?guī)硪黄猟edecms頁面如何獲取會(huì)員狀態(tài)的實(shí)例代碼。一起跟隨小編過來看看吧,希望對(duì)大家有所幫助。2016-03-03教你如何自定義百度分享插件以及bshare分享插件的分享按鈕
在項(xiàng)目中我們常用到百度分享插件或者bshare分享插件,雖然官方都有自定義按鈕的功能,但是畢竟還是只有少數(shù)幾種,我們?nèi)绾蝸碇谱饔凶约禾厣姆窒戆粹o呢?2014-06-06