循环通过节点列表JS

时间:2016-03-10 16:03:56

标签: javascript html css

我的问题是:我试图通过课堂热点的NODELIST。我想将他们的className改为' cool' 。当我使用for循环时,似乎它的第二个li并没有改变颜色。有谁知道我的错误是什么,第二个li元素不会改变颜色。

谢谢



var elements = document.getElementsByClassName('hot');
var i;

for(i = 0; i < elements.length; i++) { 
  elements[i].className = 'cool';
}
&#13;
*{
  box-sizing: border-box;
}
.hot {
  background-color: red;
  border: 1px solid black;
  padding: 10px;
  margin-top: 1px;
  font-size: 25px;
  list-style-type: none;
}

.cool {
  background-color: blue;
  padding: 10px;
  color: white;
  font-size: 25px;
}
&#13;
<html>
  <body>
   <div id="page">
      <h1 id="header">List</h1>
      <h2>Buy Greoceries</h2>
      <ul>
         <li id="one" class="hot"><em>Fresh</em>figs</li>
         <li id="two" class="hot">pine nuts</li>
         <li id="three" class="hot">honey</li>
         <li id="four">balsamic vinegear</li>
     </ul>
   </div> 
  </body>
</html>
&#13;
&#13;
&#13;

1 个答案:

答案 0 :(得分:4)

getElementsByClassName返回实时节点列表。一旦你在一个元素上更改了类,节点列表就会更新以反映这一点,所以你的索引总是会出来。

缓解此问题的一种方法是使用Array.slice.call将节点列表转换为静态节点列表:

var elements = [].slice.call(document.getElementsByClassName('hot'));

DEMO

正如您所指出的,另一种方法是使用返回静态节点列表的document.querySelectorAll

document.querySelectorAll('.hot');

DEMO