如何在前端用js判断一个元素在一个数组中是否存在
2016-10-27 14:30
996 查看
一、jQuery
如果是用JQuery的话,可以用inArray()函数:
jquery inarray()函数详解
jquery.inarray(value,array)
确定第一个参数在数组中的位置(如果没有找到则返回 -1 )。
determine the index of the first parameter in the array (-1 if not found).
返回值
jquery
参数
value (any) : 用于在数组中查找是否存在
array (array) : 待处理数组。
用法为:
[javascript] view
plain copy
$.inArray(value, array)
二、自己写函数
[javascript] view
plain copy
function contains(arr, obj) {
var i = arr.length;
while (i--) {
if (arr[i] === obj) {
return true;
}
}
return false;
}
用法为:
[javascript] view
plain copy
var arr = new Array(1, 2, 3);
contains(arr, 2);//返回true
contains(arr, 4);//返回false
三、给Array增加一个函数
[javascript] view
plain copy
Array.prototype.contains = function (obj) {
var i = this.length;
while (i--) {
if (this[i] === obj) {
return true;
}
}
return false;
}
使用方法:
[javascript] view
plain copy
[1, 2, 3].contains(2); //返回true
[1, 2, 3].contains('2'); //返回false
四、使用indexOf
但是有个问题是IndexOf在某些IE版本中是不兼容的,可以用下面的方法:
[javascript] view
plain copy
if (!Array.indexOf) {
Array.prototype.indexOf = function (obj) {
for (var i = 0; i < this.length; i++) {
if (this[i] == obj) {
return i;
}
}
return -1;
}
}
先判断Array是否有indexOf方法,如果没有就扩展出此方法。
所以上面代码要写在使用indexOf方法的代码之前:
[javascript] view
plain copy
var arr = new Array('1', '2', '3');
if (!Array.indexOf) {
Array.prototype.indexOf = function (obj) {
for (var i = 0; i < this.length; i++) {
if (this[i] == obj) {
return i;
}
}
return -1;
}
}
var index = arr.indexOf('1');//为index赋值为0
如果是用JQuery的话,可以用inArray()函数:
jquery inarray()函数详解
jquery.inarray(value,array)
确定第一个参数在数组中的位置(如果没有找到则返回 -1 )。
determine the index of the first parameter in the array (-1 if not found).
返回值
jquery
参数
value (any) : 用于在数组中查找是否存在
array (array) : 待处理数组。
用法为:
[javascript] view
plain copy
$.inArray(value, array)
二、自己写函数
[javascript] view
plain copy
function contains(arr, obj) {
var i = arr.length;
while (i--) {
if (arr[i] === obj) {
return true;
}
}
return false;
}
用法为:
[javascript] view
plain copy
var arr = new Array(1, 2, 3);
contains(arr, 2);//返回true
contains(arr, 4);//返回false
三、给Array增加一个函数
[javascript] view
plain copy
Array.prototype.contains = function (obj) {
var i = this.length;
while (i--) {
if (this[i] === obj) {
return true;
}
}
return false;
}
使用方法:
[javascript] view
plain copy
[1, 2, 3].contains(2); //返回true
[1, 2, 3].contains('2'); //返回false
四、使用indexOf
但是有个问题是IndexOf在某些IE版本中是不兼容的,可以用下面的方法:
[javascript] view
plain copy
if (!Array.indexOf) {
Array.prototype.indexOf = function (obj) {
for (var i = 0; i < this.length; i++) {
if (this[i] == obj) {
return i;
}
}
return -1;
}
}
先判断Array是否有indexOf方法,如果没有就扩展出此方法。
所以上面代码要写在使用indexOf方法的代码之前:
[javascript] view
plain copy
var arr = new Array('1', '2', '3');
if (!Array.indexOf) {
Array.prototype.indexOf = function (obj) {
for (var i = 0; i < this.length; i++) {
if (this[i] == obj) {
return i;
}
}
return -1;
}
}
var index = arr.indexOf('1');//为index赋值为0
相关文章推荐
- js判断一个对象数组里是否存在某个元素
- js判断一个对象数组里是否存在某个元素
- indexOf() 如何判断一个元素在指定数组中是否存在? 找出指定元素出现的所有位置? indexOf()方法 是正序查找,lastIndexOf()是倒叙查找
- javascript(jquery)中如何判断一个元素在页面中是否存在
- js 判断一个元素是否在页面中存在
- 编写js扩展方法实现判断一个数组中是否包含某个元素
- js判断一个元素是否在数组中
- js 判断一个元素是否存在
- JS如何判断数组中是否存在某字符串
- C#实现如何判断一个数组中是否有重复的元素
- 编写js扩展方法判断一个数组中是否包含某个元素
- js 判断一个元素是否存在
- 如何判断一个整数数组中是否有重复元素?要求时间复杂度O(n),空间复杂度O(1)
- javascript中如何判断一个元素在页面中是否存在(转)
- 如何判断一个整数数组中是否有重复元素?要求时间复杂度O(n),空间复杂度O(1)
- js如何判断一个变量是否是数组?
- jquery和js如何判断一个对象是否存在
- 如何用JS判断网页中某个id的网页元素是否存在
- jquery and js 判断一个元素是否存在
- js如何判断一组数字是否连续,得到一个临时数组[[3,4],[13,14,15],[17],[20],[22]];