--- title: Document.getElementsByClassName() slug: Web/API/Document/getElementsByClassName translation_of: Web/API/Document/getElementsByClassName --- <p id="Summary">{{APIRef("DOM")}}</p> <p>Возвращает массивоподобный (итерируемый) объект всех дочерних элементов, соответствующих всем из указанных имён классов. В случае вызова по отношению к объекту 'document', поиск происходит по всему документу, включая корневой элемент. Вызывать {{domxref("Element.getElementsByClassName", "getElementsByClassName()")}} можно также применительно к любому элементу: возвращены будут лишь те элементы, которые являются потомками указанного корневого элемента и имеют при этом указанные классы.</p> <h2 id="Syntax" name="Syntax">Синтаксис</h2> <pre class="syntaxbox"><var>var elements</var> = document.getElementsByClassName(<em>names</em>); // или: <var>var elements</var> = rootElement.getElementsByClassName(<em>names</em>);</pre> <ul> <li><var>В "elements"</var> будет текущая {{ domxref("HTMLCollection") }} найденных элементов.</li> <li><var>"names"</var> - строка, состоящая из списка имён искомых классов; имена классов разделяют пробелами.</li> <li>getElementsByClassName может быть вызвана по отношению к любому элементу, не только для документа целиком. ("document"). Элемент, по отношению к которому осуществляется вызов, используется для целей поиска в качестве корневого элемента.</li> </ul> <h2 id="Examples" name="Examples">Примеры</h2> <p>Получить все элементы класса 'test':</p> <pre class="brush: js">document.getElementsByClassName('test');</pre> <p>Получить все элементы, для которых заданы класс 'red' и класс 'test':</p> <pre class="brush: js">document.getElementsByClassName('red test');</pre> <p>Получить все элементы класса 'test', являющиеся дочерними для элемента с ID 'main':</p> <pre class="brush: js">document.getElementById('main').getElementsByClassName('test');</pre> <p>Мы также можем использовать методы из Array.prototype по отношению к любой {{ domxref("HTMLCollection") }}, передавая коллекцию в качестве значения <em>this</em> метода. Код в примере найдёт все элементы 'div' с классом 'test':</p> <pre class="brush: js">var testElements = document.getElementsByClassName('test'); var testDivs = Array.prototype.filter.call(testElements, function(testElement){ return testElement.nodeName === 'DIV'; });</pre> <h2 id="Получение_элементов_класса_'test'">Получение элементов класса 'test'</h2> <p>Ниже приведён пример наиболее употребительного способа использования данного метода.</p> <pre><!doctype html> <html> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="parent-id"> <p>hello word1</p> <p class="test">hello word2</p> <p >hello word3</p> <p>hello word4</p> </div> <script> var parentDOM = document.getElementById("parent-id"); var test=parentDOM.getElementsByClassName("test");//test is not target element console.log(test);//HTMLCollection[1] var testTarget=parentDOM.getElementsByClassName("test")[0];//hear , this element is target console.log(testTarget);//<p class="test">hello word2</p> </script> </body> </html></pre> <h2 id="Совместимость_браузеров">Совместимость браузеров</h2> <p>{{Compat("api.Document.getElementsByClassName")}}</p> <h2 id="Specification" name="Specification">Спецификация</h2> <ul> <li><a href="https://dvcs.w3.org/hg/domcore/raw-file/tip/Overview.html#dom-document-getelementsbyclassname" title="https://dvcs.w3.org/hg/domcore/raw-file/tip/Overview.html#dom-document-getelementsbyclassname"><span class="external">W3C: getElementsByClassName</span></a></li> </ul>