Jquery遍历数组之$.inArray()方法介绍

Posted Green.Leaf

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Jquery遍历数组之$.inArray()方法介绍相关的知识,希望对你有一定的参考价值。

$.inArray()函数用于在数组中搜索指定的值,并返回其索引值。如果数组中不存在该值,则返回-1;

$.inArray(value,array)    --value是要查找的值,array是被查找的数组。

 

 

使用$.inArray()方法必须注意的点,否则会掉坑

(1)看如下代码:

        $(function () {
              var arr=[{"name":"张三"},{"name":"李四"},{"name":"王五"}];
              alert($.inArray({"name":"张三"}, arr));
        });

上面这段代码不仔细分析怎么看都没有错,但是返回值是-1。下面来分析下原因发现:

错误的原因是{"name":"张三"}和{"name":"张三"}是两个不同的引用;所以在arr数组里面找不到{"name":"张三"}这个对象;代码如果这样改就可以了

        $(function () {
            var obj = { "name": "张三" };
            var arr = [{ "name": "李四" }, obj, { "name": "王五"}];
            alert($.inArray(obj, arr));
        });

这段代码返回的就是1;返回值正常;

 

(2)大家都知道javascript是一种弱类型语言,对于数字类型和字符类型,可以随意切换(例如:1+""="1");所以有以下一段代码:

        $(function () {
            var arr = [1, 2, 3, 4, 5];
            var a = 2;
            alert($.inArray(a, arr)); });

这段代码返回正常值为1;

        $(function () {
            var arr = [1, 2, 3, 4, 5];
            var a = "2";
            alert($.inArray(a, arr));
        });

当把a的值改为字符串2返回值就出错了为-1;所以各位在使用这个$.inArray()方法时,一定要确保数据类型是一样的,虽然javascript是一种弱类型语言;

 

以上是关于Jquery遍历数组之$.inArray()方法介绍的主要内容,如果未能解决你的问题,请参考以下文章

jQuery.inArray( value, array )

jquery 判断元素是否存在于数组中

jquery数组问题

JQuery判断数组中是否包含某个元素$.inArray("元素字符串", 数组名称);

jquery怎麽删除数组中元素

js找数组中元素5种方式