首頁 >web前端 >js教程 >關於IE中getElementsByClassName不能用的問題解決方法_javascript技巧

關於IE中getElementsByClassName不能用的問題解決方法_javascript技巧

WBOY
WBOY原創
2016-05-16 17:24:191227瀏覽

今天使用getElementsByClassName寫了段小程序,滿懷欣喜的準備去測試,在ff,谷歌等主流瀏覽器上測試都沒問題,在IE9上也沒問題,在IE6、8中測試的時候就出現問題了,瀏覽器報錯誤。糾結了下代碼,似乎沒問題,果斷找度娘。 。 。終於發現問題所在,然來是IE6、8中不支援getElementsByClassName這種方法。接著在網路上搜尋解決方法,找到了一個比較好的方法,是個老外寫的一個方法,定睛一看居然是05年的問題了。 。 。先上程式碼:

複製程式碼 程式碼如下:

* Developed by Robertman , http://www.robertnyman.com
Code/licensing: http://code.google.com/p/getelementsbyclassname/
*/
var getElementsByClassName = function (className, tag, elm) {
if (document.getElementsByClassName) {
getElementsByClassName = function (className, tag, elm) {
elm = elm || document;
var elements = elelm.getElementsByClassName( >nodeName = (tag)? new RegExp("\b" tag "\b", "i") : null,
returnElements = [],
current;
for(var i=0, il=elements.length; icurrent = elements[i];
if(!nodeName || nodeName.test(current.nodeName)) {
returnElements.push (current);
}
}
return returnElements;
};
}
else if (document.evaluate) {
getElementsByClassName = function (document.evaluate) {
getElementsByClassName = function (className, tag, eltionel ) {
tag = tag || "*";
elm = elm || document;
var classes = className.split(" "),
classesToCheck = "",
xhtmlNamespace = "http://www.w3.org/1999/xhtml",
namespaceResolver = (document.documentElement.namespaceURI === xhtmlNamespace)? xhtmlNamespace : null,
returnElements = [],
elements ,
node;
for(var j=0, jl=classes.length; jclassesToCheck = "[contains(concat(' ', @class, ' ' ), ' " classes[j] " ')]";
}
try {
elements = document.evaluate(".//" tag classesToCheck, elm, namespaceResolver, 0, null);
}
catch (e) {
elements = document.evaluate(".//" tag classesToCheck, elm, null, 0, null);
}
while ((node = elements .iterateNext())) {
returnElements.push(node);
}
return returnElements;
};
}
else {
getElementsByClassName = ftionuncsClassName = ftionuncsB. tag, elm) {
tag = tag || "*";
elm = elm || document;
var classes = className.split(" "),
classesToCheck = [],
elements = (tag === "*" && elm.all)? elm.all : elm.getElementsByTagName(tag),
current,
returnElements = [],
match;
for(var k=0, kl=classes.length; kclassesToCheck.push(new RegExp("(^|\s)" classes[k] "(\s|$ )"));
}
for(var l=0, ll=elements.length; lcurrent = elements[l];
match = false ;
for(var m=0, ml=classesToCheck.length; mmatch = classesToCheck[m].test(current.className);
if (!match ) {
break;
}
}
if (match) {
returnElements.push(current);
}
}
return returnElements;
}
}
return returnElements;
;
; };
}
return getElementsByClassName(className, tag, elm);
};

具體怎麼使用可以去看他裡面的使用方法。 使用這個方法之後,IE6、8中能顯示了,但是還是有個隨機的問題,有時刷新幾次又會報錯,暫時無解了。然後我想用jquery能不能解決這個刷新報錯的問題,當然用jquery也能取代getElementsByClassName這個方法,具體怎麼用這裡就不作介紹了。然而事實終不能如人願,刷新還是會有問題,而且報錯是隨機的,有時第一次加載過程中就報錯,有時刷新幾次才報錯。大俠們。求解決。
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn