温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何解决JS中getElementsByClassName与classList兼容性问题

发布时间:2021-08-02 15:11:19 来源:亿速云 阅读:199 作者:小新 栏目:web开发

这篇文章主要为大家展示了“如何解决JS中getElementsByClassName与classList兼容性问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决JS中getElementsByClassName与classList兼容性问题”这篇文章吧。

具体如下:

document(element).getElementsByClassName(classNames:classString);

HTML5新添加了这个方法,这个方法可以通过document和html元素调用,接受一个参数,这个参数包含一个或多个类名的字符串,返回带有制定类型的NodeList(存在性能问题),传入的多个类型顺序不重要。这个方法仅仅在标准浏览器下有效,在非标准浏览器下无效。

<body>     <p class="p1 p">p1 p</p>     <p class="p"> p</p>     <script type="text/javascript">         var aP = document.getElementsByClassName(' p p1' );         alert(aP.length);         /*标准 : 1*/         /*非标准:Error:对象不支持“getElementsByClassName”属性或方法*/     </script> </body>

解决兼容性的方式:

var getElementsByClassName = (function (classList,/*optional*/parent){     if(typeof classList !== "string") throw TypeError("the type of classList is error");     var parent = parent || window.document;/*添加默认值*/     if(parent.getElementsByClassName){/*如果是标准浏览器支持该方法*/       return parent.getElementsByClassName(classList);     }else{/*如果不支持该方法即非标准浏览器*/       var child = parent.getElementsByTagName("*");       var nodeList = [];       /*获得classList的每个类名 解决前后空格 以及两个类名之间空格不止一个问题*/       var classAttr = classList.replace(/^\s+|\s+$/g,"").split(/\s+/);       for(var j = 0,len_j = child.length; j<len_j; j++){         var element = child[j];         for(var i = 0,len_i = classAttr.length; i< len_i; i++){           var _className = classAttr[i];           if(element.className.search(new RegExp("(\\s+)?"+_className+"(\\s+)?")) === -1){             break;           }         }         if(i===len_i) nodeList.push(element);       }       return nodeList;     } });

classList属性

classList属性是HTML5新增的一个属性,在这个属性下有几个方法:

Add(value)将给定的字符串值增加到列表中,如果存在,就不会添加。
Contains(value)表示列表中是否存在给定的值,如果存在返回true,否则返回false。
Remove(value)从列表中删除给定的字符串。
Toggle(value)如果列表中已经存在给定的值,删除它,如果没有给定的值,增加它。

支持classList的浏览器有Firefox3.6+和chrome和IE10+。

解决兼容性:

var classList = null; (function(){     classList = function (obj){       this.obj = obj;     };     classList.prototype.add = function(value){       if(typeof value !== "string") throw TypeError("the type of value is error");       if(this.obj.classList){         this.obj.classList.add(value);       }else{         var arr = value.replace(/^\s+|\s+$/g,"").split(/\s+/);         this.obj.classList +=" "+arr.join(" ");       }     };     classList.prototype.contains = function(value){       if(typeof value !== "string") throw TypeError("the type of value is error");       if(this.obj.classList){         return this.obj.classList.contains(value);       }else{         var arr = value.replace(/^\s+|\s+$/g,"").split(/\s+/);         var _className = this.obj.className;         for(var i = 0,len= arr.length; i<len; i++){           if(_className.search(new RegExp("(\\s+)?"+arr[i]+"(\\s+)?"))===-1){             return false;           }         }         return true;       }     };     classList.prototype.remove = function(value){       if(typeof value !== "string") throw TypeError("the type of value is error");       if(this.obj.classList){         return this.obj.classList.remove(value);       }else{         var arr = value.replace(/^\s+|\s+$/g,"").split(/\s+/);         var _className = this.obj.className;         for(var i = 0, len = arr.length;i<len; i++){           if(_className.search(new RegExp("(\\s+)?"+arr[i]+"(\\s+)?"))!==-1){             _className = _className.replace(new RegExp("(\\s+)?"+arr[i]+"(\\s+)?"),"");           }         }         this.obj.className = _className;       }     };     classList.prototype.toggle = function(value){       if(typeof value !== "string") throw TypeError("the type of value is error");       if(this.contains(value)){         this.remove(value);       }else{         this.add(value);       }     }; })();

以上是“如何解决JS中getElementsByClassName与classList兼容性问题”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI