티스토리 뷰
프로그래밍/Front end
[Front end] JavaScript Json Key 추출 ( keys VS getOwnPropertyNames 비교)
Reference M1 2020. 1. 10. 23:46
Json 데이터 Key를 뽑는 방법은 아래와 같다.
let jsonData = {
userId : 'ID0001',
userNm : '홍길두',
age : 22
};
let key1 = Object.keys(jsonData);
console.log(key1);
let key2 = Object.getOwnPropertyNames(jsonData);
console.log(key2);

동일한 결과를 보여준다. 결과가 같아 보이는데 왜 함수를 다를까? 두 함수의 차이를 알아보자. JavaScript에서 객체의 속성을 정의할 때 enumerable(열거자)를 지정할 수 있다.
let object = Object.create({}, {
name: {value : 'Micheal', enumerable : false},
gender: {value : 'Male', enumerable : false}
});
let key1 = Object.keys(object);
console.log(key1);
let key2 = Object.getOwnPropertyNames(object);
console.log(key2);


enumerable 값에 따라 결과가 달라진 걸 확인할 수 있다. 결과적으로 어떤 Object를 다룰 때 객체의 모든 Key를 추출하고자 한다면 getOwnPropertyNames 함수를 사용하자. 부가적으로 미세하지만 keys 보다 getOwnPropertyNames이 빠르다.
'프로그래밍 > Front end' 카테고리의 다른 글
| [Front end] Javascript 파일첨부 확장자 선택 (0) | 2020.01.22 |
|---|---|
| [Front end] Javascript 웹 브라우저 현재 URL 확인 (0) | 2020.01.14 |
| [Front end] JavaScript 동적 form 생성 및 submit (0) | 2020.01.09 |
| [Front end] 바닐라 자바스크립트 기초 #2 Function, DOM, Event (0) | 2019.11.13 |
| [Front end] 바닐라 자바스크립트 기초 #1 Variable, Data Types (0) | 2019.11.09 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
링크
TAG
- 경력관리
- Linux 명령어
- 제주도 여행
- Collection
- 개발환경
- React
- javascript
- 성능분석
- Maven
- 소프트웨어공학
- 회고
- 정렬 알고리즘
- effective java
- 오라클 내장 함수
- 자바
- 자바스크립트
- Tomcat
- 리눅스 명령어
- spring
- 프로그래머스
- 오라클
- Eclipse
- 프로그래머
- 제주도 3박4일 일정
- SQL
- 리액트 16
- Java
- 리액트
- 이직
- sort algorithm
| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 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 |
글 보관함