我很难弄清楚如何移动数组元素。例如,给出以下内容:
var arr = [ 'a', 'b', 'c', 'd', 'e'];
我为什么能写入移动功能'd'之前'b'?
'd'
'b'
还是'a'之后'c'?
'a'
'c'
移动后,应更新其余元素的索引。这意味着在第一个示例中,移动后arr [0] =’a’,arr [1] =’d’arr [2] =’b’,arr [3] =’c’,arr [4] = ‘e’
这似乎应该很简单,但是我无法将其包裹住。
如果您想在npm上使用一个版本,则array-move与该答案最接近,尽管它的实现方式不同。有关更多详细信息,请参见其用法部分。可以在npm的array.prototype.move上找到此答案的先前版本(修改后的Array.prototype.move)。
使用此功能,我取得了相当不错的成功:
function array_move(arr, old_index, new_index) { if (new_index >= arr.length) { var k = new_index - arr.length + 1; while (k--) { arr.push(undefined); } } arr.splice(new_index, 0, arr.splice(old_index, 1)[0]); return arr; // for testing }; // returns [2, 1, 3] console.log(array_move([1, 2, 3], 0, 1));
请注意,最后一个return仅用于测试目的:splice就地对数组执行操作,因此不需要返回。通过扩展,这move是就地操作。如果要避免这种情况并返回副本,请使用slice。
return
splice
move
slice
逐步执行代码:
new_index
undefined
arr.splice(old_index, 1)[0]
[1]
1
new_index > arr.length
解释负指数的更高级的版本:
function array_move(arr, old_index, new_index) { while (old_index < 0) { old_index += arr.length; } while (new_index < 0) { new_index += arr.length; } if (new_index >= arr.length) { var k = new_index - arr.length + 1; while (k--) { arr.push(undefined); } } arr.splice(new_index, 0, arr.splice(old_index, 1)[0]); return arr; // for testing purposes }; // returns [1, 3, 2] console.log(array_move([1, 2, 3], -1, -2));
哪个应该说明类似的事情array_move([1,2,3],-1,-2)(将最后一个元素移到倒数第二个位置)。结果应该是[1, 3, 2]。
array_move([1,2,3],-1,-2)
[1, 3, 2]
无论哪种方式,在您最初的问题中,您都array_move(arr,0,2)将为aafter做c。对于d以前b,你会做array_move(arr, 3, 1)。
array_move(arr,0,2)
a
c
d
b
array_move(arr, 3, 1)