关于getElementsByClassName

本文介绍了在使用CSS和JavaScript过程中遇到的问题及解决方案,特别是如何正确使用getElementsByClassName方法,并提供了一个兼容旧版IE浏览器的实现方案。

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

开始重新学习css和js,一直使用的是jQuery,好多js的东西没有注意到。比如今天遇到的getElementsByClassName。

使用getElementsByClassName获取div,控制它的样式,一直提示对象的“style”属性不存在,想了好久,终于看到它获取到的是集合,不是单个dom元素,使用下角标[0]获取到了该元素。

查看了一下,该方法支持ie9以上,其他的ie版本并不支持该方法,所以尽量少用。

当然,可以自己写方法来弥补:

window.onload = function () {
            var tagName = getClass("div", "classname");

                     for (var i = 0; i < tagName.length; i++) {  // 返回多个元素的数组

                tagName[i].innerHTML = "你好";
            }
        }

        function getClass(tagname, className) { // tagname指元素,className指class的值

                   if (document.getElementsByClassName) {   // 判断浏览器是否支持getElementsByClassName,如果支持就直接的用

               return getElementsByClassName(className);
            }
            else {   
// 当浏览器不支持getElementsByClassName的时候用下面的方法
               var tagname = document.getElementsByTagName(tagname);  

               var tagnameAll = [];    //这个数组用于存储所有符合条件的元素
               for (var i = 0; i < tagname.length; i++) {    
// 遍历获得的元素
                    if (tagname[i].className == className) {    
// 如果获得的元素中的class的值等于指定的类名,就赋值给tagnameAll
                        tagnameAll[tagnameAll.length] = tagname[i];
                    }
                }
               return tagnameAll;

            }
        }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值