--- title: Element.classList slug: Web/API/Element/classList translation_of: Web/API/Element/classList ---
Свойство classList
возвращает псевдомассив {{domxref("DOMTokenList")}}, содержащий все классы элемента.
У classList есть примитивная альтернатива - свойство className, которое содержит значение атрибута class элемента.
var elementClasses = elem.classList;
ClassList является геттером. Возвращаемый им объект имеет несколько методов:
сlassList[Number]
И, конечно же, у ClassList есть заветное свойство length, которое возвращает количество классов у элемента.
<div id="clock" class="example for you"> </div>
var elem = document.querySelector("#clock") //Выведем классы console.log(elem.classList); //DOMTokenList ["example", "for", "you"] //Добавим классы elem.classList.add("ok", "understand"); console.log(elem.classList); //DOMTokenList ["example", "for", "you", "ok", "understand"] //Переключим классы elem.classList.toggle("you"); elem.classList.toggle("he"); console.log(elem.classList); //DOMTokenList ["example", "for", "ok", "understand", "he"] //Проверим класс console.log(elem.classList.contains("example")); //true console.log(elem.classList.contains("lol")); //false //И удалим классы elem.classList.remove("example", "for", "understand", "he"); console.log(elem.classList); //DOMTokenList ["ok"]
В Firefox 25- в методах add, remove и toggle возможно указать только один аргумент. Смотрите: https://bugzilla.mozilla.org/show_bug.cgi?id=814014
// Источник: https://gist.github.com/k-gun/c2ea7c49edf7b757fe9561ba37cb19ca ;(function() { // helpers var regExp = function(name) { return new RegExp('(^| )'+ name +'( |$)'); }; var forEach = function(list, fn, scope) { for (var i = 0; i < list.length; i++) { fn.call(scope, list[i]); } }; // class list object with basic methods function ClassList(element) { this.element = element; } ClassList.prototype = { add: function() { forEach(arguments, function(name) { if (!this.contains(name)) { this.element.className += ' '+ name; } }, this); }, remove: function() { forEach(arguments, function(name) { this.element.className = this.element.className.replace(regExp(name), ''); }, this); }, toggle: function(name) { return this.contains(name) ? (this.remove(name), false) : (this.add(name), true); }, contains: function(name) { return regExp(name).test(this.element.className); }, // bonus.. replace: function(oldName, newName) { this.remove(oldName), this.add(newName); } }; // IE8/9, Safari if (!('classList' in Element.prototype)) { Object.defineProperty(Element.prototype, 'classList', { get: function() { return new ClassList(this); } }); } // replace() support for others if (window.DOMTokenList && DOMTokenList.prototype.replace == null) { DOMTokenList.prototype.replace = ClassList.prototype.replace; } })();
Особенность | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari (WebKit) |
---|---|---|---|---|---|
Basic support | 8.0 | {{ CompatGeckoDesktop("1.9.2") }} | 10 | 11.50 | 5.1 {{Webkitbug("20709")}} |
toggle method's second argument | 24 | {{CompatGeckoDesktop("24")}} | not supported | 15 | yes {{Webkitbug("99375")}}
|
Особенность | Android | Firefox Mobile (Gecko) | IE Phone | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|
Basic support | 3.0 | {{CompatGeckoMobile("1.9.2")}} | 10 | 11.10 | 5.0 |
toggle method's second argument | ? | {{CompatGeckoMobile("24")}} | ? | ? | ? |