코딩 스쿨 JavaScript

언어선택 : HTMLCSSJAVAJAVASCRIPTMYSQLSQL PHP
▶ JavaScript Tutorial
JavaScript HOME
JavaScript Introduction
JavaScript Where To
JavaScript Output
JavaScript Statements
JavaScript Syntax
JavaScript Comments
JavaScript Variables
JavaScript Let
JavaScript Const
JavaScript Operators
JavaScript Arithmetic
JavaScript Assignment
JavaScript Data Types
JavaScript Functions
JavaScript Objects
JavaScript Object Properties
JavaScript Object Methods
JavaScript Object Display
JavaScript Object Constructors
JavaScript Events
JavaScript Strings
JavaScript String Methods
JavaScript String Search
JavaScript String Templates
JavaScript Numbers
JavaScript BigInt
JavaScript Number Methods
JavaScript Number Properties
JavaScript Arrays
JavaScript Array Methods
JavaScript Array Search
JavaScript Array Sort
JavaScript Array Iteration
JavaScript Array Const
JavaScript Dates
JavaScript Date Formats
JavaScript Date Get Methods
JavaScript Date Set Methods
JavaScript Math
JavaScript Random
JavaScript Booleans
JavaScript Comparisons
JavaScript If Else
JavaScript Switch
JavaScript Loop For
JavaScript Loop For In
JavaScript Loop For Of
JavaScript Loop While
JavaScript Break
JavaScript Iterables
JavaScript Sets
JavaScript Set Methods
JavaScript Maps
JavaScript Map Methods
JavaScript Typeof
JavaScript Type Conversion
JavaScript Destructuring
JavaScript Bitwise
JavaScript RegExp
JavaScript Precedence
JavaScript Errors
JavaScript Scope
JavaScript Hoisting
JavaScript Strict Mode
JavaScript this Keyword
JavaScript Arrow Function
JavaScript Classes
JavaScript Modules
JavaScript JavaScriptON
JavaScript Debugging
JavaScript Style Guide
JavaScript Best Practices
JavaScript Mistakes
JavaScript Performance
JavaScript Reserved Words

JavaScript Array Search

JavaScript Array Search: 배열 검색의 이해와 활용

JavaScript 배열에서 특정 요소를 찾거나 검색하는 작업은 매우 일반적입니다. JavaScript는 배열 내에서 특정 값이나 조건에 맞는 값을 찾기 위한 다양한 내장 메서드를 제공합니다. 이 가이드는 배열 내에서 요소를 검색하는 방법을 설명하고, 이를 위한 주요 메서드를 소개합니다.


1. 배열 검색을 위한 주요 메서드

1.1. indexOf()

indexOf() 메서드는 배열에서 특정 값이 처음으로 나타나는 인덱스를 반환합니다. 만약 값이 배열에 존재하지 않으면 -1을 반환합니다.

const fruits = ["apple", "banana", "cherry", "banana"];
console.log(fruits.indexOf("banana")); // 출력: 1
console.log(fruits.indexOf("grape"));  // 출력: -1

1.2. lastIndexOf()

lastIndexOf() 메서드는 배열에서 특정 값이 마지막으로 나타나는 인덱스를 반환합니다. 만약 값이 배열에 존재하지 않으면 -1을 반환합니다.

console.log(fruits.lastIndexOf("banana")); // 출력: 3
console.log(fruits.lastIndexOf("grape"));  // 출력: -1

1.3. includes()

includes() 메서드는 배열에 특정 값이 포함되어 있는지 확인하고, 포함되어 있으면 true, 그렇지 않으면 false를 반환합니다.

console.log(fruits.includes("cherry")); // 출력: true
console.log(fruits.includes("grape"));  // 출력: false


2. 조건에 따른 배열 검색

2.1. find()

find() 메서드는 주어진 조건을 만족하는 배열의 첫 번째 요소를 반환합니다. 조건을 만족하는 요소가 없으면 undefined를 반환합니다.

const numbers = [10, 20, 30, 40];
const result = numbers.find(num => num > 25);
console.log(result); // 출력: 30

2.2. findIndex()

findIndex() 메서드는 주어진 조건을 만족하는 배열의 첫 번째 요소의 인덱스를 반환합니다. 조건을 만족하는 요소가 없으면 -1을 반환합니다.

const index = numbers.findIndex(num => num > 25);
console.log(index); // 출력: 2


3. 배열의 일부 요소 검색

3.1. filter()

filter() 메서드는 주어진 조건을 만족하는 모든 요소를 배열로 반환합니다. 조건을 만족하는 요소가 없으면 빈 배열을 반환합니다.

const evenNumbers = numbers.filter(num => num % 2 === 0);
console.log(evenNumbers); // 출력: [10, 20, 30, 40]


4. 배열 요소의 여부 확인

4.1. some()

some() 메서드는 배열의 요소 중 하나라도 주어진 조건을 만족하면 true를 반환합니다. 모든 요소가 조건을 만족하지 않으면 false를 반환합니다.

const hasLargeNumber = numbers.some(num => num > 35);
console.log(hasLargeNumber); // 출력: true

4.2. every()

every() 메서드는 배열의 모든 요소가 주어진 조건을 만족하면 true를 반환하고, 하나라도 만족하지 않으면 false를 반환합니다.

const allEven = numbers.every(num => num % 2 === 0);
console.log(allEven); // 출력: true


5. 고급 검색: 객체 배열 검색

배열의 요소가 객체일 때 특정 속성값을 기준으로 검색할 수 있습니다.

5.1. 객체 배열에서 find()

객체 배열에서 특정 속성 값을 기반으로 객체를 검색할 수 있습니다.

const users = [
    { id: 1, name: "Alice" },
    { id: 2, name: "Bob" },
    { id: 3, name: "Charlie" }
];

const user = users.find(user => user.name === "Bob");
console.log(user); // 출력: { id: 2, name: "Bob" }

5.2. 객체 배열에서 filter()

객체 배열에서 특정 조건을 만족하는 모든 객체를 검색할 수 있습니다.

const userList = users.filter(user => user.id > 1);
console.log(userList);
// 출력:
// [
//   { id: 2, name: "Bob" },
//   { id: 3, name: "Charlie" }
// ]


6. 요약

  • indexOf()lastIndexOf(): 배열에서 특정 값의 인덱스를 찾습니다.
  • includes(): 배열에 특정 값이 포함되어 있는지 확인합니다.
  • find()findIndex(): 조건을 만족하는 첫 번째 요소나 그 인덱스를 반환합니다.
  • filter(): 조건을 만족하는 모든 요소를 배열로 반환합니다.
  • some()every(): 배열의 요소가 조건을 만족하는지 여부를 확인합니다.
  • 객체 배열 검색: 배열의 각 요소가 객체인 경우, 특정 속성을 기준으로 검색할 수 있습니다.

JavaScript의 배열 검색 메서드를 활용하면 배열에서 원하는 요소를 쉽게 찾을 수 있습니다. 각 메서드를 적절히 사용하여 검색 작업을 효율적으로 처리해보세요!


copyright ⓒ 스타트코딩 all rights reserved.
이메일 : startcodingim@gamil.com