未捕获的类型错误:无法读取未定义的属性 0

时间:2021-03-26 18:42:10

标签: javascript bar-chart

我正在尝试制作一个条形图排序器。单击按钮时,它将对条形图进行排序。但是当我运行 sort 函数时,它给了我这个错误。 我试过在我的文件中搜索拼写错误,因为这是其他答案中推荐的内容。

提前致谢。

这是我的 JS:

document.getElementById('sort').onclick = () => {
        setTimeout(function(){
              for (let i = 0; i < 8; i++) {
              let g = document.getElementsByClassName('bar');
              g[i].style.height = sort()[i]
              console.log(sort()[i])
        }},100)
}

function sort() {
    let array = [];
    for (let i = 0; i < 8; i++) {
        let g = document.getElementsByClassName('bar');
        array.push(parseInt(g[i].innerText));
        if (i >= 8) {
            return sortItems(array)
        }
    }
}

function sortItems(array) { 
    var length = array.length; 
  
      for(var i = 1, j; i < length; i++) { 
        var temp1 = array[i]; 
        for(var j = i - 1; j >= 0 && array[j] > temp1; j--) { 
          array[j+1] = array[j]; 
        } 
        array[j+1] = temp1; 
      } 
    return array; 
  }

这是我的 html:

<button id="regenerate">Regenerate</button>
    <button id="sort">Sort</button>
    <div class="bars">
        <div class="bar" id="bar1"><p class="barlabel"></p></div>
        <div class="bar" id="bar2"><p class="barlabel"></p></div>
        <div class="bar" id="bar3"><p class="barlabel"></p></div>
        <div class="bar" id="bar4"><p class="barlabel"></p></div>
        <div class="bar" id="bar5"><p class="barlabel"></p></div>
        <div class="bar" id="bar6"><p class="barlabel"></p></div>
        <div class="bar" id="bar7"><p class="barlabel"></p></div>
        <div class="bar" id="bar8"><p class="barlabel"></p></div>
    </div>
    <script src="index.js"></script>

1 个答案:

答案 0 :(得分:1)

我们来看看 sort() 函数中的这个 for 循环:

for (let i = 0; i < 8; i++) {
        let g = document.getElementsByClassName('bar');
        array.push(parseInt(g[i].innerText));
        if (i >= 8) {
            return sortItems(array)
        }
}

它只在 i >= 8 时返回一个数组,但循环本身只会迭代 i < 8。这意味着 sort() 函数永远不会返回任何内容。

在这行 g[i].style.height = sort()[i] 中,您期望一个数组作为 sort() 的返回值,但它实际上是 undefined。只需用 console.log(typeof sort()) 证明即可。