JavaScript 等效于 PHP 的 in_array()

新手上路,请多包涵

JavaScript中有没有办法比较一个数组中的值并查看它是否在另一个数组中?

类似于 PHP 的 in_array 函数?

原文由 roflwaffle 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 407
2 个回答

不,它没有。出于这个原因,大多数流行的库都在其实用程序包中附带了一个。查看 jQuery 的 inArray 和 Prototype 的 Array.indexOf 示例。

jQuery 的实现和你想象的一样简单:

 function inArray(needle, haystack) {
    var length = haystack.length;
    for(var i = 0; i < length; i++) {
        if(haystack[i] == needle) return true;
    }
    return false;
}

如果您正在处理数量合理的数组元素,则上述方法会很好地解决问题。

编辑:哎呀。我什至没有注意到您想查看一个数组是否在另一个数组中。根据 PHP 文档,这是 PHP 的 in_array 的预期行为:

 $a = array(array('p', 'h'), array('p', 'r'), 'o');

if (in_array(array('p', 'h'), $a)) {
    echo "'ph' was found\n";
}

if (in_array(array('f', 'i'), $a)) {
    echo "'fi' was found\n";
}

if (in_array('o', $a)) {
    echo "'o' was found\n";
}

// Output:
//  'ph' was found
//  'o' was found

Chris 和 Alex 发布的代码不遵循这种行为。 Alex 的是 Prototype 的 indexOf 的正式版,而 Chris 的更像 PHP 的 array_intersect 。这可以满足您的要求:

 function arrayCompare(a1, a2) {
    if (a1.length != a2.length) return false;
    var length = a2.length;
    for (var i = 0; i < length; i++) {
        if (a1[i] !== a2[i]) return false;
    }
    return true;
}

function inArray(needle, haystack) {
    var length = haystack.length;
    for(var i = 0; i < length; i++) {
        if(typeof haystack[i] == 'object') {
            if(arrayCompare(haystack[i], needle)) return true;
        } else {
            if(haystack[i] == needle) return true;
        }
    }
    return false;
}

这是我对上面的测试:

 var a = [['p','h'],['p','r'],'o'];
if(inArray(['p','h'], a)) {
    alert('ph was found');
}
if(inArray(['f','i'], a)) {
    alert('fi was found');
}
if(inArray('o', a)) {
    alert('o was found');
}
// Results:
//   alerts 'ph' was found
//   alerts 'o' was found

请注意,我故意没有扩展 Array 原型,因为这样做通常是个坏主意。

原文由 Paolo Bergantino 发布,翻译遵循 CC BY-SA 3.0 许可协议

var value = 'a';
var array = ['a', 'b', 'c'];
if(array.indexOf(value)){
    // exists in array
} else {
   // Not exists in array
}

原文由 Hamid Raza 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题