国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

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

2019-11-19 11:03:59
字體:
來源:轉載
供稿:網友

本文實例講述了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程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宽甸| 扬州市| 威宁| 鹿泉市| 滦平县| 屏南县| 木兰县| 施甸县| 库伦旗| 英山县| 武穴市| 洱源县| 盱眙县| 容城县| 涟水县| 禹州市| 金昌市| 彰化县| 陈巴尔虎旗| 文登市| 盐边县| 嘉义县| 遂溪县| 利辛县| 静乐县| 裕民县| 巴塘县| 宝应县| 东源县| 舟曲县| 通许县| 治多县| 白城市| 株洲县| 威远县| 土默特右旗| 泰州市| 仁化县| 玉屏| 镇远县| 伊通|