- 전체
- HTML
- Web Design (웹디자인)
- XE 응용 개발
- wordpress plugin dev
- Javascript & JavaScript Application
- MEAN Stack : full stack javascript
- angular js & ionic framework
- bootstrap
- WebGL, Three.js and Babylon.js
- restful api design
- mobile web
- node.js 응용
- Cloud Service 응용
- 웹 어셈블리 개발 [WASM, WebAssembly]
- 마이크로서비스, MSA (microservice architecture)
- WebGL / WebGPU
- next.js 개발
- micro frontend (마이크로프론트앤드)
JavaScript [JavaScript] 자바스크립트 객체 배열에서 indexOf 사용방법
2023.01.26 22:20
[JavaScript] 자바스크립트 객체 배열에서 indexOf 사용방법
기본적인 배열은 일반 변수들이 나열된 모양이다.
var arr = [ "사과", "딸기", "복숭아 ];
var arr2 = [ 5, 3, 0.5, 7, 2, 9];
이런 일반적인 배열에서 인덱스를 통해 배열의 값을 구할수있다.
console.log(arr[0]); // "사과" 출력
console.log(arr2[2]); // 0.5 출력
반대로 배열의 값을 아는경우에 해당 배열의 몇번째 인덱스인지 indexOf함수를 사용하여 다음처럼 구할수있다.
console.log(arr.indexOf("복숭아")); // 2 출력
console.log(arr2.indexOf(5)); // 0 출력
하지만 자바스크립트에서 배열의 원소들이 객체(object)라면 어떻게 될까?
아래의 예를 살펴보자.
var arr3 = [
{ num : 0, name : "홍길동" },
{ num : 1, name : "박보검" },
{ num : 2, name : "강호동" }
];
위와 같은 객체배열이 존재한다고 가정하자.
객체 배열에서 객체안의 변수를 구하려면 다음과 같이 사용한다.
console.log(arr3[1].name); // "박보검" 출력
console.log(arr3[2].num); // 2 출력
그렇다면 반대로 "강호동"이라는 문자열을 가지고 2라는 인덱스를 구하려면 어떻게해야할까?
(실제로 프로그래밍도중 해당 지식이 필요하여 찾아서 정리한것이다..)
답은 findIndex() 함수를 사용하면 된다. 예를 통해 살펴보자.
var index = arr3.findIndex(i => i.name == "강호동");
여기서 index의 값으로 2를 반환받는다.
i라는 변수명은 아무거나 적어도 작동하는것을 보였다. 하지만 다른 변수이름과 중복되면 왠지모를 찝찝함이 생기므로
obj나 안쓰는 다른 변수명을 사용하자.
그럼이제 저 index를 사용하여 해당 배열에 접근할수있겠지?
[출처] https://yeolco.tistory.com/157
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.