일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- WebView
- 스쿠버다이빙
- 여행
- guide
- window10
- poe2
- Front-end
- ubuntu
- 페오엑
- 세부
- 개발툴
- 취미
- 엘든링
- PostgreSQL
- 젤다의전설
- 야생의숨결
- 게임
- psql
- 어드벤스
- docker
- 씨홀스
- 오픈워터
- JavaScript
- 뱀파이어서바이벌
- JS
- 공략
- 다이빙
- Linux
- window
- hybride
- Today
- Total
Rianshin
[JS] forEach, for in, for of의 차이 본문
forEach는 Array의 prototype을 상속받은 객체가 사용할 수 있는 함수이다. 반복문이 아니라 '함수'이다. 인자로 함수를 받아 각 배열의 요소에 해당 함수를 적용한다.
developer.mozilla.org/ko/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach
developer.mozilla.org/ko/docs/Web/JavaScript/Reference/Statements/for...in
for in은 Object에 있는 key에 차례로 접근하는 데 사용되는 반복문이다. Array에도 사용할 수도 있지만 일반적으로 Object를 제외한 객체에는 사용하지 않는 것이 좋다. 왜냐하면 for in으로 순회를 하게 되면 해당 요소뿐 아니라 prototype chain을 따라 확장 속성들도 함께 순회하기 때문이다. 아래 예시를 보자.
object의 요소뿐 아니라 Object의 prototype으로 만들어 둔 foo 함수까지 함께 순회하는 모습을 볼 수 있다. 이러한 이유 때문에 for in은 Object의 key를 순회하기 위해 불가피하게 사용하는 것이 아니라면 사용하지 않는 것이 좋다. Object를 for in이 아닌 다른 방법으로 순회하고 싶다면, Object의 내장 메소드인 keys()를 사용하면 된다.
developer.mozilla.org/ko/docs/Web/JavaScript/Reference/Statements/for...of
마지막으로 for of이다. for of는 이터러블한 객체의 순회를 도와주는 반복문이다. 때문에 Array만 반복할 수 있는 forEach와 다르게, 내부에 [Symbol.iterator]를 가진 객체라면 어떤 객체든 순회할 수 있다. 하지만 iterable하지 않은 일반 Object에는 사용할 수 없다.
* 요약
1. forEach는 Array를 순회하는 데 사용되는 Array의 메소드.
2. for in은 Object의 key를 순회하기 위해 사용되는 반복문. 단, 확장 속성까지 함께 순회한다는 점 고려.
3. for of는 이터러블한 객체를 모두 순회할 수 있는 강력한 반복문!
'Develop > Javascript' 카테고리의 다른 글
[JS]대문자, 소문자 변환 (0) | 2022.09.07 |
---|---|
[ES6] map과 filter 올바르게 사용하기 (0) | 2022.03.03 |
[javascript] $.each(), some, forEach 알고 사용하자 (0) | 2020.12.23 |
[jQuery] 체크박스 컨트롤.. (0) | 2020.12.21 |
[JS]setInterval(), clearInterval(), setTimeout() (0) | 2020.12.14 |