js 二维数组比较大小问题。

报错:Uncaught TypeError: Cannot read property '1' of undefined

console.log()能访问到数字,为什么比较时就会出错?

<p id="abc">aaaaaa</p>
<script>
    var data = [
      ["北京", 10],
      ["上海", 20],
      ["福州", 30],
      ["广州", 40],
      ["成都", 40],
      ["西安", 100]
    ];

    var abc = document.getElementById('abc');
    j = 0;
    for (var i = 0; i < data.length; i++) {
        console.log(data[i][1]);
        if (data[i][1] > data[i+1][1]) {
            j++;
        };
    }

    abc.innerHTML = j;
</script>
阅读 4.3k
3 个回答

这个报错是溢出数组,现在data.length=6,当i=5是,i+1=6就溢出了。
<p id="abc">aaaaaa</p>
<script>

var data = [
  ["北京", 10],
  ["上海", 20],
  ["福州", 30],
  ["广州", 40],
  ["成都", 40],
  ["西安", 100]
];

var abc = document.getElementById('abc');
j = 0;
for (var i = 0; i < data.length; i++) {
    console.log(data[i][1]);
    if(i<data.length-1){
        if (data[i][1] > data[i+1][1]) {
            j++;
        };
    }
}

abc.innerHTML = j;

</script>

这样就不会报错了。

你可以这样写:

var data = [
    ["北京", 10],
    ["上海", 20],
    ["福州", 30],
    ["广州", 40],
    ["成都", 40],
    ["西安", 100]
];
var abc = document.getElementById('abc');
var j = 0;
var max = data[0][1];
for (let i = 1; i < data.length; i++) {
    let temp = data[i][1];
    
    if (temp > max) {
        j = i;
        max = temp;
    }
}
abc.innerHTML = data[j][0];
因为数组越界了,当i = data.length - 1的时候, data[i+1][1]访问的就是 data[6][1],data[6]其实是没有的,因为他最大的才是data[5], 说的有点乱,不知道能看懂不
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题