我是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}));