Javascript将多维数组中的每个元素加倍的方法



我是javascript新手,被要求做这个学徒测试,我还没有走得很远,只是需要一些帮助…我所要做的就是将多维数组中的每个数字加倍,并将其打印到网页上,对不起,如果这对某些人来说似乎很简单,我是相对较新的,所以不知道很多。

        // Define a 2 dimensional (3 x 3) array
        var array = [
            [1, 2, 3],
            [4, 5, 6],
            [7, 8, 9]
        ];

        // TO DO: Double each number in the 2 dimensional array

这就是我到目前为止所拥有的,不确定我是否在正确的轨道上?

        for (var i = 0; i < array[0].length + array.length; i++){
            for (var j = 0; j <array[0].length +array.length; j++){
            array[i] = array[i] * 2;
                document.write(array[i][j])
                }
            }


        // Output results
        document.write(array.toString(array));
        // Say how big the array is
        document.write("<p>Table is " + array[0].length + " columns by " + array.length + " rows</p>");
        // Start the table
        document.write("<table>");
        // Output the rows
        document.write("<tr><td>" + array[0][0] + "</td><td>" + array[0][1] + "</td><td>" + array[0][2] + "</td></tr>");
        document.write("<tr><td>" + array[1][0] + "</td><td>" + array[1][1] + "</td><td>" + array[1][2] + "</td></tr>");
        document.write("<tr><td>" + array[2][0] + "</td><td>" + array[2][1] + "</td><td>" + array[2][2] + "</td></tr>");
        // End the table
        document.write("</table>");
        // Optionally... make the above "output the rows" code work with
        // any sized array
    </script>
</body>

您可以使用.map()而不是for循环,使其更简洁。

var arr = [
    [1, 2, 3],
    [4, 5, 6],
    [7, 8, 9]
];
arr = arr.map(function (sub_arr) {
    return sub_arr.map(function (elem) {
        return elem*2;
    });
});
console.log(arr);

或者选择使用ES6语法

arr = arr.map(sub_arr => sub_arr.map(elem => elem*2));
console.log(arr);

您生成输出的逻辑不是最好的,但它应该工作得很好,尽管我会使用循环来生成输出,而不是静态编码[0][0],[0][1],[0][2]等…

您可以这样做;

var arrays = [
  [1, 2, 3],
  [4, 5, 6],
  [7, 8, 9]
];
for (var array of arrays)
  for (var item of array) logout.textContent += +item * 2 + ",";
<pre id="logout"></pre>

你也可以像这样循环使用forEach:

arr.forEach(item => item.forEach((elem, index, array) => {array[index] = 2 * elem}));

相关内容

  • 没有找到相关文章