17

我想做一个像这样工作的函数:

function arraySearch(array, valuetosearchfor)
{
// some code
}

如果它在数组中找到值,它将返回找到值的键。如果有多个结果(多个键),或根本没有结果(未找到),则该函数将返回 FALSE。

我找到了这段代码:

function arraySearch(arr,val) 
        {
            for (var i=0; i<arr.length; i++)
                {
                    if (arr[i] == val) 
                    {                    
                        return i;
                    }
                    else 
                    {
                        return false;
                    }
                }
        }

并像这样使用它:

var resultofarraycheck = arraySearch(board, chosen);
                if (resultofarraycheck === false) 
                {
                       document.getElementById(buttonid).value;
                       chosen = 0;
                }

但这似乎不起作用。当它应该找到某些东西时,它返回 false 而不是键 (i)。

我该如何解决这个问题,或者我做错了什么?

谢谢,如果我的英语不够清楚,我很抱歉。

4

5 回答 5

27
function arraySearch(arr,val) {
    for (var i=0; i<arr.length; i++)
        if (arr[i] === val)                    
            return i;
    return false;
  }
于 2012-10-28T14:41:45.770 回答
15

您可以使用 indexOf 获取关键 jsfiddle

if(!Array.prototype.indexOf){
    Array.prototype.indexOf = function(val){
        var i = this.length;
        while (i--) {
            if (this[i] == val) return i;
        }
        return -1;
    } 
}

    var arr = ['a','b','c','d','e'];

    var index = arr.indexOf('d'); // return 3
于 2012-10-28T14:41:09.870 回答
2
function arraySearch(arr, val) {
  var index;
  for (var i = 0; i < arr.length; i++) {
    // use '===' if you strictly want to find the same type
    if (arr[i] == val) {
      if (index == undefined) index = i;
      // return false if duplicate is found
      else return false;
    }
  }

  // return false if no element found, or index of the element
  return index == undefined ? false : index;
}

希望这可以帮助 :)

于 2012-10-28T14:53:30.340 回答
1

这是现在 Array Prototype 上的一种方法: https ://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findIndex

var array1 = [5, 12, 8, 130, 44];

function findFirstLargeNumber(element) {
  return element > 13;
}

console.log(array1.findIndex(findFirstLargeNumber));
// expected output: 3
于 2018-04-30T19:36:29.197 回答
0

如果您计划大量查找特定数组的不同值的索引,最好使用映射到数组的值和索引的键值对创建一个对象。

const letters = ["a", "b", "c"]
const letterIndices = letters.reduce((acc, letter, index) => 
    Object.assign(acc, {[letter]: index}), {}
)

letterIndices["b"] // gives 1
于 2019-03-28T17:39:18.387 回答