>웹 프론트엔드 >JS 튜토리얼 >JavaScript 배열에서 요소의 모든 인덱스를 찾는 방법은 무엇입니까?

JavaScript 배열에서 요소의 모든 인덱스를 찾는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-01 00:26:02315검색

How to Find All Indexes of an Element in a JavaScript Array?

배열에서 요소 발생 인덱스를 얻는 방법

배열 내 요소의 모든 인스턴스 인덱스를 식별하는 것은 일반적인 프로그래밍 작업입니다. JavaScript에서 배열은 .indexOf() 및 .includes()와 같은 메서드를 제공하지만 처음 또는 마지막 항목만 반환합니다. 모든 인스턴스에 대한 인덱스를 얻으려면 다른 접근 방식이 필요합니다.

루프 및 .indexOf() 사용

한 가지 효과적인 방법은 .indexOf()를 사용하여 요소 발생을 반복적으로 확인하는 것입니다. 다음 함수는 이 접근 방식을 보여줍니다.

<code class="js">function getAllIndexes(arr, val) {
  var indexes = [], i = -1;
  while ((i = arr.indexOf(val, i + 1)) != -1) {
    indexes.push(i);
  }
  return indexes;
}</code>

이 함수에서는 시작 인덱스가 증가하면서 .indexOf() 메서드가 반복적으로 호출됩니다. 주어진 값의 인스턴스를 찾을 때마다 해당 인덱스가 인덱스 배열에 추가됩니다.

표준 For 루프 사용

또 다른 효율적인 방법은 간단한 for 루프입니다.

<code class="js">function getAllIndexes(arr, val) {
  var indexes = [], i;
  for (i = 0; i < arr.length; i++) {
    if (arr[i] === val) {
      indexes.push(i);
    }
  }
  return indexes;
}</code>

이 for 루프는 배열을 반복하면서 각 요소를 지정된 값과 비교합니다. 일치하는 항목이 발견되면 루프는 해당 인덱스를 인덱스 배열에 추가합니다.

사용 예

이 두 접근 방식 모두 "Nano" 요소의 모든 항목에 대한 인덱스를 찾는 데 사용할 수 있습니다. Cars 배열:

<code class="js">var Cars = ["Nano", "Volvo", "BMW", "Nano", "VW", "Nano"];

var indexes = getAllIndexes(Cars, "Nano");</code>

이제 indexes 변수에는 Cars 배열의 모든 "Nano" 인스턴스 인덱스를 포함하는 배열이 포함됩니다: [0, 3, 5].

위 내용은 JavaScript 배열에서 요소의 모든 인덱스를 찾는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.