Нет, у него его нет. По этой причине большинство популярных библиотек поставляются с одной в своих пакетах утилит. Посмотрите jQuery's inArray и Прототип * 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
Код, опубликованный Крисом и Алексом, не соответствует этому поведению. Алекс - это официальная версия Prototype indexOf, а Крис больше похож на 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, так как это обычно плохая идея.