Javascript获取类名方法

本文介绍了一种在JavaScript中获取任意对象构造函数名称的方法。通过分析对象的构造函数及其toString方法,可以有效地提取出对象所属的类名。

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

直接上函数:

protected getClassName(obj) {
        if (obj && obj.constructor && obj.constructor.toString()) {
            if(obj.constructor.name) {
                return obj.constructor.name;
            }
            let str = obj.constructor.toString();
            let arr;
            if(str.charAt(0) == '[')
            {
                arr = str.match(/\[\w+\s*(\w+)\]/);
            } else {
                arr = str.match(/function\s*(\w+)/);
            }
            if (arr && arr.length == 2) {
                return arr[1];
            }
        }
        return undefined; 
    }

JavaScript获取类名数组的方法通常涉及通过 DOM 操作获取元素集合,然后提取这些元素的类名。由于通过 `document.getElementsByClassName()` 获取的是类数组对象(HTMLCollection),通常需要将其转换为标准数组以便进一步操作。 以下是一些常用的方法获取类名数组: ### 使用 `document.getElementsByClassName` 通过 `document.getElementsByClassName` 获取元素集合,然后使用 `Array.from` 或 `Array.prototype.slice.call` 将类数组转换为数组: ```javascript const elements = document.getElementsByClassName('example-class'); const classNamesArray = Array.from(elements).map(el => el.className); console.log(classNamesArray); ``` ### 使用 `document.querySelectorAll` 通过 `document.querySelectorAll` 可以直接获取一个 NodeList,它类似于数组,可以通过 `Array.from` 转换为数组: ```javascript const elements = document.querySelectorAll('.example-class'); const classNamesArray = Array.from(elements).map(el => el.className); console.log(classNamesArray); ``` ### 使用 `Array.prototype.slice.call` 转换 如果环境不支持 `Array.from`,可以使用 `slice.call` 来转换类数组对象: ```javascript const elements = document.getElementsByClassName('example-class'); const classNamesArray = Array.prototype.slice.call(elements).map(el => el.className); console.log(classNamesArray); ``` ### 动态处理类名 如果需要动态处理类名并将其转换为数组,可以结合 `map` 方法进行操作: ```javascript const elements = document.getElementsByClassName('example-class'); const classNamesArray = Array.from(elements).map(el => { return el.classList.value; // 获取元素的类名字符串 }); console.log(classNamesArray); ``` ### 注意事项 - `document.getElementsByClassName` 返回的是实时更新的 HTMLCollection,如果 DOM 发生变化,这个集合会自动更新。 - `document.querySelectorAll` 返回的是静态的 NodeList,不会随着 DOM 的变化而更新[^3]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值