如何用值找到数组索引?

jdb*_*org 188 javascript arrays indexof

说我有这个

imageList = [100,200,300,400,500];
Run Code Online (Sandbox Code Playgroud)

哪能给我

[0]100 [1]200 等等

在JavaScript中有什么方法可以返回带有值的索引吗?

即我想要200的索引,我得到返回1.

voi*_*tan 301

你可以使用indexOf:

var imageList = [100,200,300,400,500];
var index = imageList.indexOf(200); // 1
Run Code Online (Sandbox Code Playgroud)

如果它无法在数组中找到值,您将获得-1.

  • 我做到了,谢谢.IE有一天会赶上现代! (4认同)
  • 你可以使用https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Array/indexOf或任何Javascript框架来解决这个问题. (2认同)
  • 刚刚发现它在IE8中不起作用。我的选择是什么? (2认同)

Jaq*_*har 64

对于对象阵列使用mapindexOf:

var imageList = [
   {value: 100},
   {value: 200},
   {value: 300},
   {value: 400},
   {value: 500}
];

var index = imageList.map(function (img) { return img.value; }).indexOf(200);

console.log(index);
Run Code Online (Sandbox Code Playgroud)


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

var imageList = [
   {value: 100},
   {value: 200},
   {value: 300},
   {value: 400},
   {value: 500}
];

var index = imageList.findIndex(img => img.value === 200);

console.log(index);
Run Code Online (Sandbox Code Playgroud)

它的ES6部分,并支持 Chrome,FF,Safari和(仅限于遗憾)IE边缘

  • @Bindrid,它写在答案中,请参见_“它是ES6的一部分,并受Chrome,FF,Safari和(仅不幸的)IE边缘支持” _ (2认同)

Sim*_*ver 16

使用jQuery的函数 jQuery.inArray

jQuery.inArray( value, array [, fromIndex ] )
(or) $.inArray( value, array [, fromIndex ] )
Run Code Online (Sandbox Code Playgroud)

  • jQuery≠Javascript (6认同)

小智 13

这是另一种在javascript中复杂数组中查找值索引的方法.希望能帮到某个人.我们假设我们有一个JavaScript数组如下,

var studentsArray =
     [
    {
    "rollnumber": 1,
    "name": "dj",
    "subject": "physics"
   },
   {
   "rollnumber": 2,
  "name": "tanmay",
  "subject": "biology"
   },
  {
   "rollnumber": 3,
   "name": "amit",
   "subject": "chemistry"
   },
  ];
Run Code Online (Sandbox Code Playgroud)

现在,如果我们需要选择数组中的特定对象.让我们假设我们想要找到名字为Tanmay的学生的索引.

我们可以通过迭代数组并比较给定键的值来做到这一点.

function functiontofindIndexByKeyValue(arraytosearch, key, valuetosearch) {

    for (var i = 0; i < arraytosearch.length; i++) {

    if (arraytosearch[i][key] == valuetosearch) {
    return i;
    }
    }
    return null;
    }
Run Code Online (Sandbox Code Playgroud)

您可以使用该函数查找特定元素的索引,如下所示,

var index = functiontofindIndexByKeyValue(studentsArray, "name", "tanmay");
alert(index);
Run Code Online (Sandbox Code Playgroud)


TRO*_*DON 8

使用indexOf

imageList.indexOf(200)
Run Code Online (Sandbox Code Playgroud)


gio*_*_13 6

怎么样indexOf

alert(imageList.indexOf(200));
Run Code Online (Sandbox Code Playgroud)


Ste*_*pUp 6

可以使用ES6函数Array.prototype.findIndex

MDN 说

findIndex()方法返回数组中满足提供的测试函数的第一个元素的索引。否则返回-1。

var fooArray = [5, 10, 15, 20, 25];
console.log(fooArray.findIndex(num=> { return num > 5; }));

// expected output: 1
Run Code Online (Sandbox Code Playgroud)

按对象属性查找索引。

要按对象属性查找索引:

yourArray.findIndex(obj => obj['propertyName'] === yourValue)
Run Code Online (Sandbox Code Playgroud)

例如,有一个这样的数组:

let someArray = [
    { property: 'OutDate' },
    { property: 'BeginDate'},
    { property: 'CarNumber' },
    { property: 'FirstName'}
];
Run Code Online (Sandbox Code Playgroud)

然后,查找必要属性索引的代码如下所示:

let carIndex = someArray.findIndex( filterCarObj=> 
    filterCarObj['property'] === 'CarNumber');
Run Code Online (Sandbox Code Playgroud)


Man*_*eUK 5

Array.indexOf在某些版本的Internet Explorer中不起作用 - 有很多替代方法可以做到这一点...请参阅此问题/答案:如何检查数组是否包含JavaScript中的对象?


小智 5

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

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);
Run Code Online (Sandbox Code Playgroud)