我试图根据给定的字符串('bananabar')创建一个数组矩阵。每个矩阵元素都应该最后取一个字符串元素并预先附加。
例如:第一个数组为['b','a','n','a','n','a','b','a','r']和下一个矩阵数组为['r','b','a','n','a','n','a','b','a']。
这是我的职能:
function createTable(s) {
var strArr = s.split('');
var arr = [];
for (i=0; i<s.length; i++) {
arr[i] = strArr;
console.log(arr[i])
strArr.unshift(strArr.pop());
}
console.log(arr, 'arr')
return arr;
}
当我在控制台上用for循环记录arr [i]时,看看是否从strArr中删除了一个数组元素并将其追加到前面,并且显示正确。以下是for循环中的控制台日志语句。
[ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ]
[ 'r', 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a' ]
[ 'a', 'r', 'b', 'a', 'n', 'a', 'n', 'a', 'b' ]
[ 'b', 'a', 'r', 'b', 'a', 'n', 'a', 'n', 'a' ]
[ 'a', 'b', 'a', 'r', 'b', 'a', 'n', 'a', 'n' ]
[ 'n', 'a', 'b', 'a', 'r', 'b', 'a', 'n', 'a' ]
[ 'a', 'n', 'a', 'b', 'a', 'r', 'b', 'a', 'n' ]
[ 'n', 'a', 'n', 'a', 'b', 'a', 'r', 'b', 'a' ]
[ 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r', 'b' ]
但是,当我控制台记录返回的结果时,它会显示以下数组数组:
[ [ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
[ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
[ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
[ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
[ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
[ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
[ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
[ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
[ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ] ]
但是我想要通过以下方式输出
[ [ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ]
[ 'r', 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a' ]
[ 'a', 'r', 'b', 'a', 'n', 'a', 'n', 'a', 'b' ]
[ 'b', 'a', 'r', 'b', 'a', 'n', 'a', 'n', 'a' ]
[ 'a', 'b', 'a', 'r', 'b', 'a', 'n', 'a', 'n' ]
[ 'n', 'a', 'b', 'a', 'r', 'b', 'a', 'n', 'a' ]
[ 'a', 'n', 'a', 'b', 'a', 'r', 'b', 'a', 'n' ]
[ 'n', 'a', 'n', 'a', 'b', 'a', 'r', 'b', 'a' ]
[ 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r', 'b' ] ]
看看您是否能找出导致问题的原因。
答案 0 :(得分:1)
这是一种方法,可以使用两次Array.from()和String.prototype.charAt():
const makeMatrix = s =>
Array.from({ length: s.length }, (_, i) =>
Array.from({ length: s.length }, (_, j) =>
s.charAt((j - i + s.length) % s.length)));
console.log(JSON.stringify(makeMatrix('bananabar')));
答案 1 :(得分:1)
出现此问题的原因是您将对 same 数组的引用推入矩阵,然后一次又一次地更改同一数组。每次push
和unshift
都会对矩阵的每一行进行处理,因为它们都是对同一数组的引用。
还有许多其他方法可以执行此操作,但是为了说明问题,这是您的原始代码,但有一点点更改。在推入矩阵之前,它使用slice()
制作数组的副本:
let strArr = ['b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r']
var arr = strArr.slice();
for (i=0; i<strArr.length; i++) {
arr[i] = strArr.slice(); // copy the array
strArr.unshift(strArr.pop());
}
console.log(arr.map(row => row.join(',')))