JS中getElementsByClassName与classList兼容性问题解决方案分析


Posted in Javascript onAugust 07, 2019

本文实例讲述了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);
      }
    };
})();

更多关于JavaScript相关内容可查看本站专题:《JavaScript操作DOM技巧总结》、《JavaScript页面元素操作技巧总结》、《JavaScript事件相关操作与技巧大全》、《JavaScript查找算法技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript错误与调试技巧总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
在修改准备发的批量美化select+可修改select时,在非IE下发现了几个问题
Jan 09 Javascript
用JavaScript将从数据库中读取出来的日期型格式化为想要的类型。
Aug 15 Javascript
js清空表单数据的两种方式(遍历+reset)
Jul 18 Javascript
基于JQuery打造无缝滚动新闻步骤详解
Mar 31 Javascript
JS实现根据用户输入分钟进行倒计时功能
Nov 14 Javascript
浅谈angular2的http请求返回结果的subcribe注意事项
Mar 01 Javascript
iOS + node.js使用Socket.IO框架进行实时通信示例
Apr 14 Javascript
一步步教你利用Canvas对图片进行处理
Sep 19 Javascript
redux中间件之redux-thunk的具体使用
Apr 17 Javascript
JavaScript函数的特性与应用实践深入详解
Dec 30 Javascript
微信小程序实现pdf、word等格式文件上传的方法
Sep 10 Javascript
深入了解JavaScript 防抖和节流
Sep 12 Javascript
javascript for循环性能测试示例
Aug 07 #Javascript
弱类型语言javascript中 a,b 的运算实例小结
Aug 07 #Javascript
解决一个微信号同时支持多个环境网页授权问题
Aug 07 #Javascript
vue+element项目中过滤输入框特殊字符小结
Aug 07 #Javascript
Vue.js项目实战之多语种网站的功能实现(租车)
Aug 07 #Javascript
javascript中的数据类型检测方法详解
Aug 07 #Javascript
scrapyd schedule.json setting 传入多个值问题
Aug 07 #Javascript
You might like
长波知识介绍
2021/03/01 无线电
PHP.MVC的模板标签系统(四)
2006/09/05 PHP
Win下如何安装PHP的APC拓展
2013/08/07 PHP
php中{}大括号是什么意思
2013/12/01 PHP
thinkphp路由规则使用示例详解和伪静态功能实现(apache重写)
2014/02/24 PHP
Laravel Eloquent ORM 实现查询表中指定的字段
2019/10/17 PHP
js鼠标点击事件在各个浏览器中的写法及Event对象属性介绍
2013/01/24 Javascript
javascript 三种方法实现获得和设置以及移除元素属性
2013/03/20 Javascript
js单独获取一个checkbox看其是否被选中
2014/09/22 Javascript
jQuery焦点图切换特效代码分享
2015/09/15 Javascript
AngularJS ng-controller 指令简单实例
2016/08/01 Javascript
nodejs更改项目端口号的方法
2018/05/13 NodeJs
opencv 识别微信登录验证滑动块位置
2018/08/07 Javascript
js核心基础之闭包的应用实例分析
2019/05/11 Javascript
vue v-for直接循环数字实例
2019/11/07 Javascript
[46:00]DOTA2上海特级锦标赛主赛事日 - 2 胜者组第一轮#4EG VS Fnatic第一局
2016/03/03 DOTA
Python基础入门之seed()方法的使用
2015/05/15 Python
python判断图片宽度和高度后删除图片的方法
2015/05/22 Python
python连接mongodb密码认证实例
2018/10/16 Python
python石头剪刀布小游戏(三局两胜制)
2021/01/20 Python
对python3 sort sorted 函数的应用详解
2019/06/27 Python
python爬取抖音视频的实例分析
2021/01/19 Python
基于PyTorch中view的用法说明
2021/03/03 Python
Linux内核产生并发的原因
2012/07/13 面试题
创业计划书中包含的9个方面
2013/12/26 职场文书
全神贯注教学反思
2014/02/03 职场文书
职业生涯规划书范文
2014/03/10 职场文书
实习单位鉴定评语
2014/04/26 职场文书
爱心活动计划书
2014/04/26 职场文书
正风肃纪剖析材料
2014/09/30 职场文书
关于颐和园的导游词
2015/01/30 职场文书
2016新年年会主持词
2015/07/06 职场文书
《追风筝的人》:人心中的成见是座大山,但请不忘初心
2019/11/15 职场文书
react中props 的使用及进行限制的方法
2021/04/28 Javascript
python scrapy简单模拟登录的代码分析
2021/07/21 Python
Python可变与不可变数据和深拷贝与浅拷贝
2022/04/06 Python