📜  JavaScript数组indexOf()

📅  最后修改于: 2020-09-27 05:46:37             🧑  作者: Mango

JavaScript Array indexOf()方法返回数组元素的第一个出现索引;如果未找到,则返回-1。

indexOf()方法的语法为:

arr.indexOf(searchElement, fromIndex)

在这里, arr是一个数组。


indexOf()参数

indexOf()方法采用:

  • searchElement-要在数组中定位的元素。
  • fromIndex (可选)-开始搜索的索引。默认情况下,它是0

从indexOf()返回值
  • 如果该元素至少存在一次,则返回该元素在数组中的第一个索引。
  • 如果在数组中找不到该元素,则返回-1

注意: indexOf()使用严格等于 (类似于三重等于运算符或=== )将searchElement与Array的元素进行比较。


示例1:使用indexOf()方法
var priceList = [10, 8, 2, 31, 10, 1, 65];

// indexOf() returns the first occurance
var index1 = priceList.indexOf(31);
console.log(index1); // 3

var index2 = priceList.indexOf(10);
console.log(index2); // 0

// second argument specifies the search's start index
var index3 = priceList.indexOf(10, 1);
console.log(index3); // 4

// indexOf returns -1 if not found
var index4 = priceList.indexOf(69.5);
console.log(index4); // -1

输出

3
0
4
-1

笔记:

  • 如果fromIndex> = array.length ,则不搜索array并返回-1
  • 如果fromIndex <0 ,则向后计算索引。例如, -1表示最后一个元素的索引,依此类推。

示例2:查找元素的所有出现
function findAllIndex(array, element) {
  indices = [];
  var currentIndex = array.indexOf(element);
  while (currentIndex != -1) {
    indices.push(currentIndex);
    currentIndex = array.indexOf(element, currentIndex + 1);
  }
  return indices;
}

var priceList = [10, 8, 2, 31, 10, 1, 65, 10];

var occurance1 = findAllIndex(priceList, 10);
console.log(occurance1); // [ 0, 4, 7 ]

var occurance2 = findAllIndex(priceList, 8);
console.log(occurance2); // [ 1 ]

var occurance3 = findAllIndex(priceList, 9);
console.log(occurance3); // []

输出

[ 0, 4, 7 ]
[ 1 ]
[]

示例3:查找元素是否存在其他添加元素
function checkOrAdd(array, element) {
  if (array.indexOf(element) === -1) {
    array.push(element);
    console.log("Element not Found! Updated the array.");
  } else {
    console.log(element + " is already in the array.");
  }
}

var parts = ["Monitor", "Keyboard", "Mouse", "Speaker"];

checkOrAdd(parts, "CPU"); // Element not Found! Updated the array.
console.log(parts); // [ 'Monitor', 'Keyboard', 'Mouse', 'Speaker', 'CPU' ]

checkOrAdd(parts, "Mouse"); // Mouse is already in the array.

输出

Element not Found! Updated the array.
[ 'Monitor', 'Keyboard', 'Mouse', 'Speaker', 'CPU' ]
Mouse is already in the array.

推荐阅读: JavaScript Array.lastIndexOf()