getElementsByClassName()

本文介绍了一种兼容多种浏览器的通过类名获取DOM元素的方法,并提供了一个实用的JavaScript函数实现。该函数解决了getElementsByClassName()方法在某些浏览器中不可用的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

通过类名获取元素:

因为浏览器兼容性问题,导致getElementsByClassName()的可用性降低,但是通过类名获取元素可以提高写代码的效率,所以封装一下。

 function getByClassName(classStr, context) {
        context=context||document;
        if(typeof document.getElementsByClassName === 'function'){
            return listToArray(document.getElementsByClassName(classStr))
        }
        let aryClass= classStr.replace(/(^ +)|( +$)/g,"").split(/ +/g);
        let eles=document.getElementsByTagName("*");
        for(let i=0;i<aryClass.length;i++){
            let curClass=aryClass[i];
            let reg=new RegExp("(^| +)"+curClass+"( +|$)");
            let ary=[];
            for(let j=0;j<eles.length;j++){
                reg.test(eles[j].className)?ary.push(eles[j]):null;
            }
            eles=ary;
        }
        return eles;
    }
  • listToArray是将类数组转化为数组的方法。
function listToArray(arg) {
        let ary=[];
        try {
            ary=[].slice.call(arg,0)
        }catch (e){
            for (let i=0;i<arg.length;i++){
                ary[ary.length]=arg[i];
            }
        }
        return ary
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值