当前位置:   article > 正文

IE 10以前的版本兼容 document element 的classList_document.documentelement.classlist

document.documentelement.classlist

本文讲述如何让 IE 10以前的版本兼容 document element 的classList。

classList是广泛使用的CSS类处理利器,可以:

  1. // div is an object reference to a <div> element with class="foo bar"
  2. div.classList.remove("foo"); //移除该div的foo 类
  3. div.classList.add("anotherclass"); //给该div添加一个
  4. // if visible is set remove it, otherwise add it
  5. div.classList.toggle("visible"); //如果该div包含visible类则移除它,否则给它添加
  6. alert(div.classList.contains("foo")); //检查当前div是否包含foo类
  7. div.classList.add("foo","bar"); //添加多个CSS 类
但是蛋疼的是IE9和IE9以前的版本不支持该属性,下面这个代码可以弥补这个遗憾:

  1. if (!("classList" in document.documentElement)) {
  2. Object.defineProperty(HTMLElement.prototype, 'classList', {
  3. get: function() {
  4. var self = this;
  5. function update(fn) {
  6. return function(value) {
  7. var classes = self.className.split(/\s+/g),
  8. index = classes.indexOf(value);
  9. fn(classes, index, value);
  10. self.className = classes.join(" ");
  11. }
  12. }
  13. return {
  14. add: update(function(classes, index, value) {
  15. if (!~index) classes.push(value);
  16. }),
  17. remove: update(function(classes, index) {
  18. if (~index) classes.splice(index, 1);
  19. }),
  20. toggle: update(function(classes, index, value) {
  21. if (~index)
  22. classes.splice(index, 1);
  23. else
  24. classes.push(value);
  25. }),
  26. contains: function(value) {
  27. return !!~self.className.split(/\s+/g).indexOf(value);
  28. },
  29. item: function(i) {
  30. return self.className.split(/\s+/g)[i] || null;
  31. }
  32. };
  33. }
  34. });
  35. }



声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号