假设我有这个

imageList = [100,200,300,400,500];

这让我

[0]100[1]200等。

在JavaScript中是否有方法返回值的索引?

例如,我想要200的索引,返回1。


当前回答

当列表不是很长时,这是我所知道的最好的方法:

function getIndex(val) {
    for (var i = 0; i < imageList.length; i++) {
        if (imageList[i] === val) {
            return i;
        }
    }
}

var imageList = [100, 200, 300, 400, 500];
var index = getIndex(200);

其他回答

使用jQuery的函数 jQuery.inArray

jQuery.inArray( value, array [, fromIndex ] )
(or) $.inArray( value, array [, fromIndex ] )

你可以使用indexOf:

var imageList = [100,200,300,400,500];
var index = imageList.indexOf(200); // 1

如果它在数组中找不到值,就会得到-1。

使用indexOf

imageList.indexOf(200)

在多维数组中。


参考阵列:

var array = [
    { ID: '100' },
    { ID: '200' },
    { ID: '300' },
    { ID: '400' },
    { ID: '500' }
];

使用filter和indexOf:

var index = array.indexOf(array.filter(function(item) { return item.ID == '200' })[0]);

使用indexOf遍历数组中的每个项:

for (var i = 0; i < array.length; i++) {
    var item = array[i];
    if (item.ID == '200') { 
        var index = array.indexOf(item);
    }
}

对于对象数组,使用map with indexOf:

var imageList = [ {值:100}, {值:200}, {值:300}, {值:400}, {值:500} ]; var index = imageList。映射(函数(img){返回img.value;}) .indexOf (200); console.log(指数);


在现代浏览器中,你可以使用findIndex:

var imageList = [ {值:100}, {值:200}, {值:300}, {值:400}, {值:500} ]; var index = imageList。findIndex(img => img。Value === 200); console.log(指数);

它是ES6的一部分,由Chrome, FF, Safari和Edge支持