推荐一个封装好的getElementsByClassName方法
推荐一个封装好的getElementsByClassName方法
发布时间:2016-12-30 来源:查字典编辑
摘要:我们知道,原生的JS给我们提供了getElementsByClassName方法,可以通过此方法获取到含有某指定class的节点集合,注意是...

我们知道,原生的JS给我们提供了getElementsByClassName方法,可以通过此方法获取到含有某指定class的节点集合,注意是集合,也就是此函数返回一个数组。

但是,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<iLen; i++){

if(reg.test(aEle[i].className)){

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+

小伙伴们自己使用一下就知道了,超级好用,扩散下给其他小伙伴吧。

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Javascript教程学习
热门Javascript教程学习
编程开发子分类