DOM清空元素内容的方法

function clear(elem) {
  while (elem.firstChild) {
    elem.firstChild.remove();
  }
}
function clear(elem) {
  elem.innerHTML = '';
}

 

注意错误做法:

function clear(elem) {
  for (let i=0; i < elem.childNodes.length; i++) {
      elem.childNodes[i].remove();
  }
}

 

这是行不通的,因为调用 remove() 会从首端开始移除 elem.childNodes 集合中的元素,因此,元素每次都从索引 0 开始。但是 i 在增加,所以元素就被跳过了。

for..of 循环的结果也跟上面一样。

 
posted @ 2020-06-10 18:13  LangZ-  阅读(3357)  评论(0编辑  收藏  举报