前面的話(huà)
既然有g(shù)etElementById()和getElementsByTagName()方法,為什么沒(méi)有g(shù)etElementsByClassName()呢?id屬性、標(biāo)簽名、class屬性并沒(méi)有什么優(yōu)劣之分啊。終于,HTML5新增了getElementsByClassName()方法,由于在CSS布局中類(lèi)名的廣泛使用,該方法正好切中痛點(diǎn),使得通過(guò)類(lèi)名選取元素不再麻煩,成為最歡迎的一個(gè)方法。接下來(lái),本文將詳細(xì)介紹該方法
使用
HTML元素的class屬性值是一個(gè)以空格隔開(kāi)的列表,可以為空或包含多個(gè)標(biāo)識(shí)符。在javascript中class是保留字,所以使用className屬性來(lái)保存HTML的class屬性值
getElementsByClassName()方法接收一個(gè)參數(shù),即一個(gè)包含一個(gè)或多個(gè)類(lèi)名的字符串,返回帶有指定類(lèi)的所有元素的類(lèi)數(shù)組對(duì)象NodeList。傳入多個(gè)類(lèi)名時(shí),類(lèi)名的先后順序不重要。與getElementsByTagName()類(lèi)似,該方法既可以用于HTML文檔對(duì)象,也可以用于element元素對(duì)象
[注意]IE8-瀏覽器不支持
<ul id="list"> <li class="a ab c">1</li> <li class="a">2</li> <li class="ac">3</li> <li class="a b c">4</li> <li class="a b">5</li> </ul> <script>//類(lèi)名中存在a成立Array.prototype.forEach.call(list.getElementsByClassName('a&