如何检查一个是否Array
包含另一个Array
?
jQuery的$.inArray()
和array.indexOf([..., ..., ...])
不工作..
如何检查一个是否Array
包含另一个Array
?
jQuery的$.inArray()
和array.indexOf([..., ..., ...])
不工作..
首先,代码:
function equal(a, b) {
if (a == b) return true;
if (a instanceof Array && b instanceof Array)
return a.length == b.length && a.every(
function (element, index) { return equal(element, b[index]); });
return false;
}
function positionIf(array, predicate) {
for (var i = 0; i < array.length; i++)
if (predicate(array[i])) break;
return i;
}
var x = [[1, 2, 3], [4, 5, 6], [7, 8, 9]];
var y = [4, 5, 6];
var z = [10, 11, 12];
function indexOfArray(array, element) {
return positionIf(
array, function (searched) { return equal(searched, element); });
}
// >>> indexOfArray(x, y);
// 1
// >>> indexOfArray(x, z);
// 3
解释:
不管其他问题如何,拥有一个通用equal
功能将是一件好事。可惜它不在标准库中。但我相信许多流行的多功能库都提供了一个。
Position-if 是执行此类操作的已知习惯用法。您会在许多语言的标准库中找到类似的函数,例如 C++ 或 Common Lisp。有一个很好,但可能某些库已经提供了它,所以检查一下(可能是下划线?)。
使代码更通用,为将来的重用创造了潜力。
返回的索引是超出数组边界的第一个索引,以防找不到元素。据我所知,Donald Knuth 首先认为这是一件更合乎逻辑的事情。我不会对此进行辩论,我只是碰巧相信这也是正确的做法。
我看到另一个答案已被接受,但我现在已经输入了这个,所以不妨发布它:)
比较字符串表示是一个聪明的解决方案,但像这样更“手动”地进行比较可能对不经意的观察者或 6 个月后的您自己更具可读性......
function isArraysEqual(a, b) {
if(!a || !b || a === b || a.length !=b.length) {
return false;
}
for(var i = 0; i < a.length; ++i) {
if (a[i] !== b[i]) {
return false;
}
}
return true;
}
function arrayContainsArray(parent, child) {
for(var i = 0; i < parent.length; ++i) {
var candidate = parent[i];
if(candidate instanceof Array && isArraysEqual(candidate, child)) {
return true;
}
}
return false;
}
var x = [[1,2,3],[4,5,6],[7,8,9]];
var y = [4,5,6];
var z = [10,11,12];
console.log("should be true: " + arrayContainsArray(x, y));
console.log("should be false: " + arrayContainsArray(x, z));
如果您的两个数组都只包含原语(如字符串或数字),最简单的方法可能是遍历数组并比较它们的字符串表示
var arr = [ ['one'], ['one', 'three'], ['one', 'two', 'three'] ];
var search = ['one', 'three'];
function arrayInArray(haystack, needle) {
needle = '' + needle; // needle.toString()
for(var i = 0; i < haystack.length; i++) {
if(needle === '' + haystack[i]) {
return i;
}
}
return -1;
}
console.log(arrayInArray(arr, search));