Extjs如何判断一个数组中某个元素是否包含某个元素
4个回答
展开全部
目标 : 判断一个数组中某个元素是否包含某个元素
思路 : 要判断数组中是否包含某个元素,从原理来来说,就是遍历整个数组,然后判断是否相等,我们来造个轮子,名字就山寨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"))
展开全部
arr.indexOf();可以得出在数组中第一个出现的位置,如果返回是-1则不存在
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
同样是.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需要
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
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里最快的一种方法,不知道是不是真的,出自
http://stackoverflow.com/questions/237104/javascript-array-containsobj
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里最快的一种方法,不知道是不是真的,出自
http://stackoverflow.com/questions/237104/javascript-array-containsobj
contains(a, obj){
for(var i = 0; i < a.length; i++) {
if(a[i] === obj){
return true;
}
}
return false;
}
分享:
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询