手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >推荐一个封装好的getElementsByClassName方法
推荐一个封装好的getElementsByClassName方法
摘要:我们知道,原生的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+

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

【推荐一个封装好的getElementsByClassName方法】相关文章:

jQuery实现表格行上移下移和置顶的方法

document.all还是document.getElementsByName?

Jquery解析json字符串及json数组的方法

JS显示日历和天气的方法

js比较日期大小的方法

js实现一个链接打开两个链接地址的方法

jQuery实现不断闪烁文字的方法

JS中的Replace方法使用经验分享

禁止按回车键提交表单的方法

动态加载jQuery的方法

精品推荐
分类导航