推荐一个封装好的getElementsByClassName方法_javascript技巧
程序员文章站
2023-12-29 22:13:04
...
我们知道,原生的JS给我们提供了getElementsByClassName方法,可以通过此方法获取到含有某指定class的节点集合,注意是集合,也就是此函数返回一个数组。
function getElementsByClassName(oEle,sClass,sEle){
if(oEle.getElementsByClassName){
return oEle.getElementsByClassName(sClass);
}else{
var aEle=oEle.getElementsByTagName(sEle || '*'),
reg=new RegExp('(^|\\s)'+sClass+'($|\\s)'),
arr=[],
i=0,
iLen=aEle.length;
//第一种:选择document下的所有class为box_box的div元素
getElementsByClassName(document,'box_box','div')[0].style.background='yellow';
但是,IE却并不支持这个方法,但这方法却是很有实用性,所以,我们又不得不专门为IE实现这么一个函数。
复制代码 代码如下:
function getElementsByClassName(oEle,sClass,sEle){
if(oEle.getElementsByClassName){
return oEle.getElementsByClassName(sClass);
}else{
var aEle=oEle.getElementsByTagName(sEle || '*'),
reg=new RegExp('(^|\\s)'+sClass+'($|\\s)'),
arr=[],
i=0,
iLen=aEle.length;
for(; i
arr.push(aEle[i]);
}
}
return arr;
}
}
使用方法:
复制代码 代码如下:
//第一种:选择document下的所有class为box_box的div元素
getElementsByClassName(document,'box_box','div')[0].style.background='yellow';
//第二种:选择document下的所有class为box-box的div元素
getElementsByClassName(document,'box-box','div')[0].style.background='yellow';
//第三种:选择document下的所有class为box-box元素
getElementsByClassName(document,'box-box')[0].style.background='yellow';
oEle、sClass是必填的,sEle是选填的。
sClass中又中横线或下划线亲测木有问题,比如说:box-box box_box;但是如果是其他特殊字符就很有可能有问题了,如:box$box… 当然可以自己加转义搞定特殊字符,如:box\\$box…
兼容性:亲测ie6+
小伙伴们自己使用一下就知道了,超级好用,扩散下给其他小伙伴吧。
推荐阅读
-
推荐一个封装好的getElementsByClassName方法_javascript技巧
-
你不知道的Vue技巧之--开发一个可以通过方法调用的组件(推荐)
-
一个js导致的jquery失效问题的解决方法_javascript技巧
-
js创建一个input数组并绑定click事件的方法_javascript技巧
-
Javascript 数组添加一个 indexOf 方法的实现代码_javascript技巧
-
JS实现点击按钮自动增加一个单元格的方法_javascript技巧
-
关于IE中getElementsByClassName不能用的问题解决方法_javascript技巧
-
JavaScript判断一个字符串是否包含指定子字符串的方法_javascript技巧
-
javascript一个无懈可击的实例化XMLHttpRequest的方法_javascript技巧
-
javascript写的简单的计算器,内容很多,方法实用,推荐_javascript技巧