欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS中getElementsByClassName與classList兼容性問題解決方案分析

 更新時間:2019年08月07日 09:51:24   作者:MaoTr  
這篇文章主要介紹了JS中getElementsByClassName與classList兼容性問題解決方案,結合實例形式分析了getElementsByClassName與classList的使用方法、原理及兼容性問題的處理技巧,需要的朋友可以參考下

本文實例講述了JS中getElementsByClassName與classList兼容性問題解決方案。分享給大家供大家參考,具體如下:

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

HTML5新添加了這個方法,這個方法可以通過document和html元素調(diào)用,接受一個參數(shù),這個參數(shù)包含一個或多個類名的字符串,返回帶有制定類型的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)如果列表中已經(jīng)存在給定的值,刪除它,如果沒有給定的值,增加它。

支持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相關內(nèi)容可查看本站專題:《JavaScript操作DOM技巧總結》、《JavaScript頁面元素操作技巧總結》、《JavaScript事件相關操作與技巧大全》、《JavaScript查找算法技巧總結》、《JavaScript數(shù)據(jù)結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript錯誤與調(diào)試技巧總結

希望本文所述對大家JavaScript程序設計有所幫助。

您可能感興趣的文章:

相關文章

  • js事件on動態(tài)綁定數(shù)據(jù),綁定多個事件的方法

    js事件on動態(tài)綁定數(shù)據(jù),綁定多個事件的方法

    今天小編就為大家分享一篇js事件on動態(tài)綁定數(shù)據(jù),綁定多個事件的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • JavaScript 動態(tài)生成方法的例子

    JavaScript 動態(tài)生成方法的例子

    動態(tài)生成方法的例子,這些方法在新對象實例化的時候創(chuàng)建
    2009-07-07
  • 基于javascript實現(xiàn)精確到毫秒的倒計時限時搶購

    基于javascript實現(xiàn)精確到毫秒的倒計時限時搶購

    現(xiàn)如今做電商網(wǎng)站必不可少的一個效果就是限時搶購,這也是各大電商網(wǎng)站的一種促銷手段。如何實現(xiàn)倒計時限時搶購,本文為大家分享了javascript實現(xiàn)倒計時限時搶購的的相關代碼,感興趣的小伙伴們可以參考一下
    2016-04-04
  • uniapp頁面通訊講解之uni.$emit、uni.$on、uni.$once和uni.$off

    uniapp頁面通訊講解之uni.$emit、uni.$on、uni.$once和uni.$off

    uni-app?是一個使用vue.js開發(fā)所有前端應用的框架,下面這篇文章主要給大家介紹了關于uniapp頁面通訊之uni.$emit、uni.$on、uni.$once和uni.$off的相關資料,需要的朋友可以參考下
    2022-09-09
  • uniapp使用高德地圖的超詳細步驟

    uniapp使用高德地圖的超詳細步驟

    使用uni-app框架開發(fā)微信小程序,可以使用高德地圖開發(fā)地圖選點、搜索位置、定位、獲取詳細的地址信息、碼值等信息,下面這篇文章主要給大家介紹了關于uniapp使用高德地圖的超詳細步驟,需要的朋友可以參考下
    2022-12-12
  • 最全面的JS倒計時代碼

    最全面的JS倒計時代碼

    這篇文章主要為大家詳細介紹了最全面的JS倒計時代碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • javascript 另一種圖片滾動切換效果思路

    javascript 另一種圖片滾動切換效果思路

    把圖片們用ul之類的包起來,并設置float。然后設置這個ul本身為absolute定位,其父標簽用relative定位。通過設置ul的left或top值,實現(xiàn)圖片隊列的滾動效果
    2012-04-04
  • js字符串類型String常用操作實例總結

    js字符串類型String常用操作實例總結

    這篇文章主要介紹了js字符串類型String常用操作,結合實例形式總結分析了javascript字符串類型String常用方法及相關操作注意事項,需要的朋友可以參考下
    2019-07-07
  • JavaScript 監(jiān)聽textarea中按鍵事件

    JavaScript 監(jiān)聽textarea中按鍵事件

    不同的瀏覽器中的事件監(jiān)聽機制是不同的,以onKeyPress事件為例。
    2009-10-10
  • javascript Canvas動態(tài)粒子連線

    javascript Canvas動態(tài)粒子連線

    這篇文章主要為大家詳細介紹了javascript Canvas動態(tài)粒子連線,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-01-01

最新評論