在JavaScript中从索引向后迭代数组

时间:2015-02-01 11:15:14

标签: javascript python arrays

我有一些Python代码可以很好地完成我想要的东西,但是尝试将其移植到JavaScript上很难干净利落。

jsonLine = [[0,1],[2,4],[4,8],[9,12],[11,16],[12,13]]
[firstX, firstY] = [9,12]

if [firstX, firstY] in jsonLine:
    index = jsonLine.index([firstX, firstY])

    lineArray.append(jsonLine[index:])
    lineArray.append(jsonLine[index::-1])

jsonLine是构成一条线的坐标数组,[firstX,firstY]是一条线的起点,由用户定义。我正在创建一个脚本,创建两条线,一条从用户选择的点开始,然后根据与用户点的距离缩短。

在这种情况下,所需的输出将是:

[[[9,12],[11,16],[12,13]],[[9,12],[4,8],[2,4],[0,1]]]

下面是我拥有的JavaScript,它获得了第一个所需的数组,但使用for循环感觉不对,如果我使用jsonLine.reverse().slice(featureArray.length-vertex),它似乎复制了推送到lineArray的数组。是否有更简洁的方法来切割数组并将其反转?

for (var vertex = 0; vertex < featureArray.length; vertex++){
     if (jsonLine[vertex][0] === firstX && jsonLine[vertex][1] === firstY) {
        console.log(jsonLine.slice(vertex))
    }

1 个答案:

答案 0 :(得分:1)

您可以创建一个查找方法来找出您感兴趣的坐标的索引。之后,应用切片并反转以获得您正在寻找的格式:

var jsonLine = [
    [0, 1],
    [2, 4],
    [4, 8],
    [9, 12],
    [11, 16],
    [12, 13]
],
    el = [9, 12],
    index, res;

function findElement() {
    var i = 0;
    for (; i < jsonLine.length; i += 1) {
        if (jsonLine[i][0] === el[0] && jsonLine[i][1] === el[1]) {
            return i;
        }
    }
    return -1;
}
index = findElement();
res = [
    [jsonLine.slice(index)],
    [jsonLine.reverse().slice(index - 1)]// -1 because you want to repeat the element.
];
console.log(res);

Fiddle

注意:正如 @RobG 在本答案的评论中指出的那样,如果您想保持数组完整,请用jsonLine.slice(0, index + 1).reverse()替换第二部分。反向修改原始数组,这可能是不受欢迎的行为(虽然在问题中是否清楚它是否清楚)。