253

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

类似于PHP的in_array功能?

4

20 回答 20

268

不,它没有。出于这个原因,大多数流行的库都在其实用程序包中附带了一个。查看 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 原型,因为这样做通常是个坏主意。

于 2009-04-23T23:47:13.743 回答
124

现在有Array.prototype.includes

includes() 方法确定数组是否包含某个元素,根据需要返回 true 或 false。

var a = [1, 2, 3];
a.includes(2); // true 
a.includes(4); // false

句法

arr.includes(searchElement)
arr.includes(searchElement, fromIndex)
于 2016-11-21T09:50:03.800 回答
67

Array.indexOf在 JavaScript 1.6 中引入,但在旧版浏览器中不受支持。值得庆幸的是,Mozilla 的小伙子们为您完成了所有艰苦的工作,并为您提供了以下兼容性:

if (!Array.prototype.indexOf)
{
  Array.prototype.indexOf = function(elt /*, from*/)
  {
    var len = this.length >>> 0;

    var from = Number(arguments[1]) || 0;
    from = (from < 0)
         ? Math.ceil(from)
         : Math.floor(from);
    if (from < 0)
      from += len;

    for (; from < len; from++)
    {
      if (from in this &&
          this[from] === elt)
        return from;
    }
    return -1;
  };
}

甚至还有一些方便的使用片段供您愉快地编写脚本。

于 2009-04-24T00:10:48.257 回答
23

PHP方式:

if (in_array('a', ['a', 'b', 'c'])) {
   // do something if true
}

我在 JS 中的解决方案:

if (['a', 'b', 'c'].includes('a')) {
   // do something if true
}
于 2020-07-29T07:33:47.150 回答
14

如果索引不按顺序,或者索引不连续,则此处列出的其他解决方案中的代码将中断。一个更好的解决方案可能是:

function in_array(needle, haystack) {
    for(var i in haystack) {
        if(haystack[i] == needle) return true;
    }
    return false;
}

而且,作为奖励,这相当于 PHP 的 array_search (用于查找数组中元素的键:

function array_search(needle, haystack) {
    for(var i in haystack) {
        if(haystack[i] == needle) return i;
    }
    return false;
}
于 2011-08-06T16:59:20.100 回答
14

您可以简单地使用w3schools 本课中解释的“包含”功能

看起来像

let myArray = ['Kevin', 'Bob', 'Stuart'];
if( myArray.includes('Kevin'))
console.log('Kevin is here');

于 2019-09-30T21:50:23.473 回答
9

有一个名为Locutus的项目,它在 Javascript 中实现 PHP 函数,并包含in_array(),您可以像在 PHP 中一样使用它。

使用示例:

in_array('van', myArray);

in_array(1, otherArray, true); // Forcing strict type
于 2012-06-07T21:51:57.590 回答
6

jQuery 解决方案可用,请在此处查看文档:http: //api.jquery.com/jquery.inarray/

$.inArray( 10, [ 8, 9, 10, 11 ] );
于 2014-12-25T21:12:22.947 回答
5
var a = [1,2,3,4,5,6,7,8,9];

var isSixInArray = a.filter(function(item){return item==6}).length ? true : false;

var isSixInArray = a.indexOf(6)>=0;
于 2013-05-24T10:14:30.877 回答
4

There is an equivalent function:

includes()

Look here: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/includes

于 2017-09-30T18:03:22.843 回答
3

如果您需要所有PHP可用参数,请使用以下命令:

function in_array(needle, haystack, argStrict) {
    var key = '', strict = !!argStrict;
    if (strict) {
        for (key in haystack) {
            if (haystack[key] === needle) {
                return true;
            }
        }
    }
    else {
        for (key in haystack) {
            if (haystack[key] == needle) {
                return true;
            }
        }
    }
    return false;
}
于 2012-06-06T15:46:21.833 回答
3

如果您只想检查单个值是否在数组中,那么 Paolo 的代码将完成这项工作。如果您想检查两个数组共有的值,那么您需要这样的东西(使用 Paolo 的 inArray 函数):

function arrayIntersect(a, b) {
    var intersection = [];

    for(var i = 0; i < a.length; i++) {
        if(inArray(b, a[i]))
            intersection.push(a[i]);
    }

    return intersection;
}

这将返回一个包含 和 的值a数组b。(在数学上,这是两个数组的交集。)

编辑:有关您的问题的解决方案,请参阅Paolo 的编辑代码。:)

于 2009-04-24T00:01:53.320 回答
3

将此代码添加到您的项目并使用对象样式的 inArray 方法

if (!Array.prototype.inArray) {
    Array.prototype.inArray = function(element) {
        return this.indexOf(element) > -1;
    };
} 
//How it work
var array = ["one", "two", "three"];
//Return true
array.inArray("one");
于 2016-03-24T08:27:55.580 回答
2

使用Dojo Toolkit,您可以使用dojo.indexOf(). 有关文档,请参阅dojo.indexOf ,有关示例,请参阅 Bryan Forbes 的Arrays Made Easy

于 2011-12-20T09:45:27.933 回答
2
function in_array(needle, haystack){

    return haystack.indexOf(needle) !== -1;
}
于 2014-01-15T19:13:35.833 回答
2
haystack.find(value => value == needle)

其中 haystack 是一个数组,而 needle 是数组中的一个元素。如果未找到元素,则返回未定义的元素,否则返回相同的元素。

于 2019-10-11T00:09:47.497 回答
1
function in_array(what, where) {
    var a=false;
    for (var i=0; i<where.length; i++) {
        if(what == where[i]) {
            a=true;
            break;
        }
    }
    return a;
}
于 2011-12-29T08:39:56.727 回答
1

我在 SO 上找到一个很棒的 jQuery 解决方案。

var success = $.grep(array_a, function(v,i) {
    return $.inArray(v, array_b) !== -1;
}).length === array_a.length;

我希望有人会在下划线中发布如何执行此操作的示例。

于 2013-10-29T16:37:50.497 回答
0

如果您打算在课堂上使用它,并且您希望它具有功能性(并且可以在所有浏览器中使用):

inArray: function(needle, haystack)
{
    var result = false;

    for (var i in haystack) {
        if (haystack[i] === needle) {
            result = true;
            break;
        }
    }

    return result;
}

希望它可以帮助某人:-)

于 2015-01-13T22:30:55.407 回答
0

in_arraywith的等价物underscore_.indexOf

例子:

_.indexOf([3, 5, 8], 8); // returns 2, the index of 8 _.indexOf([3, 5, 8], 10); // returns -1, not found

于 2015-01-13T16:56:44.840 回答