我需要编写一个只输出数组内对象索引的函数,显然,在下面的例子中使用$ .inArray返回就好了。
array = ['one', 'two', 'three'];
$.inArray('one', array) // 0
使用更复杂的数组,如何找到嵌套在其中的对象的索引?
array = [
{
name: 'One', // index??
data: {
title: 'Title One',
content: 'Content One'
}
},
{
name: 'Two',
data: {
title: 'Title Two',
content: 'Content Two'
}
},
{
name: 'Three',
data: {
title: 'Title Three',
content: 'Content Three'
}
}
];
我听说过$ .grep()方法,indexOf()..不知道用哪一个来返回对象所在索引的整数
答案 0 :(得分:4)
您不需要预先编写的函数,只需迭代数组并比较name
属性:
function findValue(array, nameWeAreLookingFor) {
for(var i = 0; i<array.length; i++) {
if(array[i].name === nameWeAreLookingFor) return i;
}
return -1;
}
答案 1 :(得分:2)
没有内置函数..但是很容易编写自己的所有风格。作为练习,您还可以使用它们来扩展jQuery,
var array = [{
name: 'One',
// index??
data: {
title: 'Title One',
content: 'Content One'
}},
{
name: 'Two',
data: {
title: 'Title Two',
content: 'Content Two'
}},
{
name: 'Three',
data: {
title: 'Title Three',
content: 'Content Three'
}}];
function findByName(name) {
var index;
$(array).each(function(i, e) {
if (e.name && e.name == name) {
index = i;
return false;
}
});
return index;
}
console.log(findByName("One")); // prints 0
// and now even better ... find by any property
function findByProperty(objects, prop, value) {
var index;
$(objects).each(function(i, e) {
if (e[prop] && e[prop] == value) {
index = i;
return false;
}
});
return index;
}
// usage
var index = findByProperty(array, "name", "One");
console.log(index); // prints 0
index = findByProperty(array, "name", "Three");
console.log(index); // prints 2
// and even more powerful
function findByFilter(objects, filter) {
var index;
$(objects).each(function(i, e) {
if (filter(i, e)) {
index = i;
return false;
}
});
return index;
}
index = findByFilter(array,function(i,e){ return e.data.title=="Title Two"; });
console.log(index); // prints 1
答案 2 :(得分:0)
您可以使用name
属性作为索引。
试试这段代码:
var indexOfObj = function(array,objName){
var len = array.length;
while(--len>=0 && array[len].name!==objName);
return len;
}
如果在数组中找不到obj,则此函数将返回-1
。