JS判断元素是否在数组内的实现代码
作者:bea
一、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
一、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) : 待处理数组。
用法为:
代码如下:
$.inArray(value, array)
二、自己写函数
function contains(arr, obj) {
var i = arr.length;
while (i--) {
if (arr[i] === obj) {
return true;
}
}
return false;
}
用法为:
代码如下:
var arr = new Array(1, 2, 3);
contains(arr, 2);//返回true
contains(arr, 4);//返回false
三、给Array增加一个函数
Array.prototype.contains = function (obj) {
var i = this.length;
while (i--) {
if (this[i] === obj) {
return true;
}
}
return false;
}
使用方法:
代码如下:
[1, 2, 3].contains(2); //返回true
[1, 2, 3].contains('2'); //返回false
四、使用indexOf
但是有个问题是IndexOf在某些IE版本中是不兼容的,可以用下面的方法:
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方法的代码之前:
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) : 待处理数组。
用法为:
代码如下:
$.inArray(value, array)
二、自己写函数
function contains(arr, obj) {
var i = arr.length;
while (i--) {
if (arr[i] === obj) {
return true;
}
}
return false;
}
用法为:
代码如下:
var arr = new Array(1, 2, 3);
contains(arr, 2);//返回true
contains(arr, 4);//返回false
三、给Array增加一个函数
Array.prototype.contains = function (obj) {
var i = this.length;
while (i--) {
if (this[i] === obj) {
return true;
}
}
return false;
}
使用方法:
代码如下:
[1, 2, 3].contains(2); //返回true
[1, 2, 3].contains('2'); //返回false
四、使用indexOf
但是有个问题是IndexOf在某些IE版本中是不兼容的,可以用下面的方法:
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方法的代码之前:
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
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- Atitit.js的键盘按键事件捆绑and事件调度
- JS中多步骤多分步的StepJump组件实例详解
- js+flash实现的5图变换效果广告代码(附演示与demo源码下载)
- js中字符串编码函数escape()、encodeURI()、encodeURIComponent()区别详解
- 基于jquery实现轮播焦点图插件
- javascript中错误使用var造成undefined
- 详解JavaScript表单验证(E-mail 验证)
- js表单验证实例讲解
- javascript创建cookie、读取cookie
- 基于javascript实现全屏漂浮广告
- JS深度拷贝Object Array实例分析
- 如何消除inline-block属性带来的标签间间隙
- JavaScript笔记之数据属性和存储器属性
- Node.js中Request模块处理HTTP协议请求的基本使用教程
- 基于JQuery打造无缝滚动新闻步骤详解
- JavaScript位移运算符(无符号) >>> 三个大于号 的使用方法详解
- JQuery实现简单的服务器轮询效果实例
- JavaScript实现复制内容到粘贴板代码
- JavaScript是如何实现继承的(六种方式)