栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

JavaScript等同于PHP的in_array()

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

JavaScript等同于PHP的in_array()

不,它没有一个。因此,大多数流行的库在其实用程序包中都附带一个库。查看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 foundn";}if (in_array(array('f', 'i'), $a)) {    echo "'fi' was foundn";}if (in_array('o', $a)) {    echo "'o' was foundn";}// Output://  'ph' was found//  'o' was found

克里斯和亚历克斯发布的代码不遵循此行为。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原型,因为这样做通常是一个坏主意。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/575150.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号