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 相关文章推荐
让textarea控件的滚动条怎是位与最下方
Apr 20 Javascript
一个基于jquery的文本框记数器
Sep 19 Javascript
js清空表单数据的两种方式(遍历+reset)
Jul 18 Javascript
js数组常用操作方法小结(增加,删除,合并,分割等)
Aug 02 Javascript
JSON 对象未定义错误的解决方法
Sep 29 Javascript
React利用插件和不用插件实现双向绑定的方法详解
Jul 03 Javascript
浅谈JavaScript的innerWidth与innerHeight
Oct 12 Javascript
微信小程序的生命周期的详解
Oct 19 Javascript
Vue + better-scroll 实现移动端字母索引导航功能
May 07 Javascript
javascript对HTML字符转义与反转义
Dec 13 Javascript
vue axios封装及API统一管理的方法
Apr 18 Javascript
仿照Element-ui实现一个简易的$message方法
Sep 14 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
从零开始 教你如何搭建Discuz!4.1论坛
2006/07/07 PHP
dedecms 批量提取第一张图片最为缩略图的代码(文章+软件)
2009/10/29 PHP
简单的php数据库操作类代码(增,删,改,查)
2013/04/08 PHP
PhpStorm 2020.3:新增开箱即用的PHP 8属性(推荐)
2020/10/30 PHP
用jQuery简化JavaScript开发分析
2009/02/19 Javascript
JavaScript 选中文字并响应获取的实现代码
2011/08/28 Javascript
深入理解javascript变量声明
2014/11/20 Javascript
JavaScript设计模式之工厂模式和构造器模式
2015/02/11 Javascript
jquery常用的12个小功能
2016/07/22 Javascript
Bootstrap php制作动态分页标签
2016/12/23 Javascript
js 作用域和变量详解
2017/02/16 Javascript
Angular2学习笔记之数据绑定的示例代码
2018/01/03 Javascript
jQuery实现的五星点评功能【案例】
2019/02/18 jQuery
vue实现浏览器全屏展示功能
2019/11/27 Javascript
Vue父子之间值传递的实例教程
2020/07/02 Javascript
JavaScript编写开发动态时钟
2020/07/29 Javascript
vue将data恢复到初始状态 &amp;&amp; 重新渲染组件实例
2020/09/04 Javascript
javascript实现点击按钮切换轮播图功能
2020/09/23 Javascript
vue实现点击出现操作弹出框的示例
2020/11/05 Javascript
如何在vue-cli中使用css-loader实现css module
2021/01/07 Vue.js
Python利用ORM控制MongoDB(MongoEngine)的步骤全纪录
2018/09/13 Python
简单了解python高阶函数map/reduce
2019/06/28 Python
python通过txt文件批量安装依赖包的实现步骤
2019/08/13 Python
win10安装tesserocr配置 Python使用tesserocr识别字母数字验证码
2020/01/16 Python
html5 canvas绘制矩形和圆形的实例代码
2016/06/16 HTML / CSS
DIY蛋糕店的创业计划书范文
2013/12/26 职场文书
兰兰过桥教学反思
2014/02/08 职场文书
小学生开学感言
2014/02/28 职场文书
教师职位说明书
2014/07/29 职场文书
项目申请汇报材料
2014/08/16 职场文书
捐款活动总结
2014/08/27 职场文书
司法局群众路线教育实践活动整改措施
2014/09/17 职场文书
培训学校2015年度工作总结
2015/07/20 职场文书
创业计划书之外语培训班
2019/11/02 职场文书
分布式架构Redis中有哪些数据结构及底层实现原理
2022/03/13 Redis
面试中canvas绘制图片模糊图片问题处理
2022/03/13 Javascript