如何在javascript中获得嵌套数组中值的indexOf位置

How to get indexOf location of a value in nested array in javascript?

本文关键字:数组 位置 indexOf 嵌套 javascript      更新时间:2023-09-26

免责声明:这个问题和这个问题不一样。

我有一个嵌套数组的例子:
var testArray = [
  true,
  "",
  [
    1,
    {a: 2, b: [3, false]},
    [2, []],
    null
  ],
  4,
  undefined,
  [5, "test"],
  function() {}
];

如何获取嵌套数组中值的indexOf,如:

testArray.multiIndexOf(null); //Expected result will be [2, 3]

我将解释这里发生了什么。

首先,我们将testArray分解为:

var testArrayExplain = [0, 1, [0, 1, [0, 1], 3], 3, 4, [0, 1], 6];

正如你在这里看到的,这个数组和上面一样:第一层数组的长度为7,然后看看位置#2的值,我们将看到另一个数组嵌套在第一个数组上。如上所述,null值与位置#3在第一个数组

位置#2中的位置完全相同。

所以我们将有第一层位置,然后是第二层位置null: [2, 3],存储在从第一层到最后一层排序的数组中。

另一个例子:

var testArrayTwo = [1,[2,3,4],5,[6,[7,8],9,10],11,12];
testArrayTwo.multiIndexOf(6); //return [3, 0]

可选:如果一个嵌套数组有两个相同的值,那么获取第一个值的位置,还是一个数组同时存储两个位置?如果值不在嵌套数组,return -1像indexOf?

我要求太多了吗?这个问题对未来的开发者很重要吗?

可以遍历数组,如果找到所需的项就停止。如果可能的话,查看嵌套数组并继续。

Array.prototype.multiIndexOf = function (value) {
    var result;
    this.some(function iter(path) {
        return function (a, i) {
            if (a === value) {
                result = path.concat(i);                        
                return true;
            };
            return Array.isArray(a) && a.some(iter(path.concat(i)));
        }
    }([]));
    return result;
}
var testArray = [true, "", [1, { a: 2, b: [3, false] }, [2, []], null], 4, undefined, [5, "test"], function () { }];
console.log(testArray.multiIndexOf(null));
console.log([1, [2, 3, 4], 5, [6, [7, 8], 9, 10], 11, 12].multiIndexOf(6));
.as-console-wrapper { max-height: 100% !important; top: 0; }

替代@Nina的答案。

作为额外的检查,我添加了

JSON.stringify(array[key]).indexOf(searchVal) > -1

如果value不可用,将忽略递归树。

var testArray = [1, [2, 3, 4], 5, [6, [7, 8], 9, 10], 11, 12]
function findIndex(array, searchVal, pindex) {
  var result = -1;
  var index = -1;
  for (var key in array) {
    index++;
    if (typeof(array[key]) === "object" &&
      JSON.stringify(array[key]).indexOf(searchVal) > -1 &&
      findIndex(array[key], searchVal, index) !== -1) {
      result = index;
      break;
    } else if (typeof(item) !== "object" && array[key] === searchVal) {
      result = index;
      break;
    }
  }
  return pindex || result;
}
var r1 = findIndex(testArray, 2);
var r2 = findIndex(testArray, 3);
var r3 = findIndex(testArray, 8);
console.log("Result: ", r1, r2, r3)

您可以使用以下函数实现您的目标。它允许您以与在数组上使用indexOf相同的方式使用deepIndexOf:

[1,[5,[2,"abc"]],3,4].deepIndexOf("abc")    //returns [1,1,1]
[1,[5,[2,"abc"]],3,4].deepIndexOf("none")    //returns -1

但是它还不能用于数组。然而,它很容易被消耗掉。

Array.prototype.deepIndexOf = function (val) {
  for (var i=0; i<this.length; i++) {
    if(this[i] == val)
      return [i];
    var insideIndex = this[i].deepIndexOf ?
            this[i].deepIndexOf(val) : -1;
    if (insideIndex != -1)
       return [i].concat(insideIndex);
  }
  return -1;
}
document.write([1,[5,[2,"abc"]],3,4].deepIndexOf("abc")
               +"<br>");
document.write([1,[5,[2,"abc"]],3,4].deepIndexOf("none"));