例如的的这个数组中有这几个元素,我想判断数组中的元素是否存在2,应该怎么判断?现在此谢过
目标 : 判断一个数组中某个元素是否包含某个元素
思路 : 要判断数组中是否包含某个元素,从原理来来说,就是遍历整个数组,然后判断是否相等,我们来造个轮子,名字就山寨PHP的数组函数in_array()
Array.prototype.in_array = function(e){
for(i=0;i<this.length;i++)
{
if(this[i] == e)
return true;
}
return false;
}
或者:
Array.prototype.in_array = function(e){
for(i=0;i<this.length && this[i]!=e;i++);
return !(i==this.length);
}
这两个都是可以的。其实就是一个形式,写法不一样而已。 还有一个大牛是这样写的
Array.prototype.S=String.fromCharCode(2);Array.prototype.in_array=function(e)
{
var r=new RegExp(this.S+e+this.S);
return (r.test(this.S+this.join(this.S)+this.S));
}
使用方法:
var arr=["a","b"];alert(arr.in_array("a"))
温馨提示:答案为网友推荐,仅供参考
第1个回答 2017-04-28
arr.indexOf();可以得出在数组中第一个出现的位置,如果返回是-1则不存在
第2个回答 2016-05-25
同样是.net3.5环境下的两个项目,一个里支持arr.contains(1),一个就不支持,代码完全相同也不行.有时在不支持项目里加新文件支持,但有时又不支持,发现在支持的项目里contains的注释是<extension方法,但是查不出在哪定义的. 在网上查到一段代码,虽然和这不太一样,但是可以使数组使用contains 数组有Contains方法,在.NET Framework 2.0 版中,Array 类实现ICollection<T接口,但必须如下书写代码:1. string[] ss =newstring[] {1,2};2. boolb = (ssasICollection<string ).Contains(1); MSDN中说明如下: 在.NET Framework 2.0 版中,Array 类实现 System.Collections.Generic.IList<T、System.Collections.Generic.ICollection<T 和 System.Collections.Generic.IEnumerable<T 泛型接口。由于实现是在运行时提供给数组的,因而对于文档生成工具不可见。因此,泛型接口不会出现在 Array 类的声明语法中,也不会有关于只能通过将数组强制转换为泛型接口类型(显式接口实现)才可访问的接口成员的参考主题。将某一数组强制转换为这三种接口之一时需要注意的关键一点是,添加、插入或移除元素的成员会引发 NotSupportedException。 下例的第二种方法是上文里讲到的三种方法之一. (1) 第一种方法: int[] ia = {1,2,3}; int id = Array.IndexOf(ia,1); // 这里的1就是你要查找的值if(id==-1)// 不存在else// 存在(2) 第二种方法: string[] strArr = {a,b,c,d,e}; bool exists = ((IList)strArr).Contains(a);if(exists)// 存在else// 不存在注意:用IList需要本回答被提问者和网友采纳
第3个回答 2016-06-15
Array.prototype.contains = function(obj) {
var i = this.length;
while (i--) {
if (this[i] === obj) {
return true;
}
}
return false;
}
或
Array.prototype.contains = function (element) {
for (var i = 0; i < this.length; i++) {
if (this[i] == element) {
return true;
}
}
return false;
}
据说while减迭代是js里最快的一种方法,不知道是不是真的,出自
contains(a, obj){
for(var i = 0; i < a.length; i++) {
if(a[i] === obj){
return true;
}
}
return false;
}
分享:
var i = this.length;
while (i--) {
if (this[i] === obj) {
return true;
}
}
return false;
}
或
Array.prototype.contains = function (element) {
for (var i = 0; i < this.length; i++) {
if (this[i] == element) {
return true;
}
}
return false;
}
据说while减迭代是js里最快的一种方法,不知道是不是真的,出自
contains(a, obj){
for(var i = 0; i < a.length; i++) {
if(a[i] === obj){
return true;
}
}
return false;
}
分享: