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 )