关于jQuery的inArray 方法介绍

转自:http://www.jb51.net/article/28486.htm

代码:

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>main</title>
</head>
<body>
<script type="text/javascript" src="jquery-1.8.3.min.js"></script>
<script>
$(function() {
    var d = "1,3,43,23,54,67";
    var arr = d.split(',');
    alert($.inArray(3, arr) == -1);// true
    alert($.inArray("3", arr) == -1);// false
    var arr = eval('[' + d + ']');
    alert($.inArray(3, arr) > -1);// true
});
</script>
</body>
</html>

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) : 待处理数组。 

代码:

var testarr=[{"a":"0"},{"b":"1"},{"c":"2"}];
alert($.inarray({"a":"0"},testarr));   
说这个值总是返回-1;

var obj = {'m' : '1'};
var arr = [obj, '1', 2];
alert($.inarray(obj, arr));
这个返回值正常。

这是对象是引用类型的缘故。

引用类型的特性可以用一小段程序演示:

代码如下:

var obj = {"a" : 0};
var obj1 = {"a" : 0};
alert(obj == obj1);// false
var obj = {"a" : 0};
var obj1 = obj;
alert(obj == obj1); // true

为此我们看下jquery中inAarry函数的源码:

/*@param elem 用于在数组中查找的项
@param array 待查找的数组
*/
inArray: function(elem, array) {
        //判断浏览器是否支持javascript1.6新增的array原生的indexOf
         if(array.indexOf) {
             return array.indexOf(elem);
         }
         var i,
             len = array.length;
         //按照array的长度进行遍查找
         for(i = 0; i < len; i++) {
               if(array[i] === elem ) {
                     // 如果array[i]的元素和elem相同
                     return i;
                }
         }
         // 没有找到的话就返回-1
         return -1;
}

注意"==="符号