자바 스크립트에서 (키, 값)을 반복하는 방법은 무엇입니까?
다음 형식의 사전이 있습니다.
dictionary = {0: {object}, 1:{object}, 2:{object}}
다음과 같은 작업을 수행하여이 사전을 반복하는 방법
for((key,value) in dictionary){
//Do stuff where key would be 0 and value would be the object
}
tl; dr
- ECMAScript 5에서는 불가능합니다.
- ECMAScript 2015에서는
Map
s를 사용 하여 가능합니다 . - ECMAScript 2017에서는 쉽게 사용할 수 있습니다.
ECMAScript 5 :
아니요, 객체로는 불가능합니다.
for..in
, 또는 Object.keys
이와 같이 반복해야합니다.
for (var key in dictionary) {
// check if the property/key is defined in the object itself, not in parent
if (dictionary.hasOwnProperty(key)) {
console.log(key, dictionary[key]);
}
}
참고 :if
위 의 조건은 dictionary
객체 자체의 속성을 반복하려는 경우에만 필요합니다 . for..in
상속 가능한 모든 열거 가능한 속성을 반복 하기 때문 입니다.
또는
Object.keys(dictionary).forEach(function(key) {
console.log(key, dictionary[key]);
});
ECMAScript 2015
ECMAScript 2015에서는을 사용하여 Map
객체 를 사용 하고 반복 할 수 있습니다 Map.prototype.entries
. 해당 페이지에서 인용 한 예,
var myMap = new Map();
myMap.set("0", "foo");
myMap.set(1, "bar");
myMap.set({}, "baz");
var mapIter = myMap.entries();
console.log(mapIter.next().value); // ["0", "foo"]
console.log(mapIter.next().value); // [1, "bar"]
console.log(mapIter.next().value); // [Object, "baz"]
또는 for..of
이와 같이 반복 하십시오.
'use strict';
var myMap = new Map();
myMap.set("0", "foo");
myMap.set(1, "bar");
myMap.set({}, "baz");
for (const entry of myMap.entries()) {
console.log(entry);
}
산출
[ '0', 'foo' ]
[ 1, 'bar' ]
[ {}, 'baz' ]
또는
for (const [key, value] of myMap.entries()) {
console.log(key, value);
}
산출
0 foo
1 bar
{} baz
ECMAScript 2017
ECMAScript 2017은 새로운 기능을 도입했습니다 Object.entries
. 이를 사용하여 원하는대로 객체를 반복 할 수 있습니다.
'use strict';
const object = {'a': 1, 'b': 2, 'c' : 3};
for (const [key, value] of Object.entries(object)) {
console.log(key, value);
}
산출
a 1
b 2
c 3
이 시도:
dict = {0:{1:'a'}, 1:{2:'b'}, 2:{3:'c'}}
for (var key in dict){
console.log( key, dict[key] );
}
0 Object { 1="a"}
1 Object { 2="b"}
2 Object { 3="c"}
이 Object.entries()
방법은 ES2017에 지정 되었으며 모든 최신 브라우저에서 지원됩니다 .
for (const [ key, value ] of Object.entries(dictionary)) {
// do something with `key` and `value`
}
설명:
Object.entries()
객체를 가져 와서{ a: 1, b: 2, c: 3 }
키-값 쌍의 배열로 바꿉니다 :[ [ 'a', 1 ], [ 'b', 2 ], [ 'c', 3 ] ]
.이를 통해
for ... of
생성 된 배열의 모든 항목을 반복 할 수 있습니다.우리 때문에 보장 소위 반복 배열의 각 항목이 다른 두 엔트리 어레이 즉, 우리가 사용 destructuring 직접 지정 변수에
key
및value
그 제 1 및 제 2 항목이다.
이 시도:
var value;
for (var key in dictionary) {
value = dictionary[key];
// your code here...
}
다음과 같이 할 수 있습니다 :
dictionary = {'ab': {object}, 'cd':{object}, 'ef':{object}}
var keys = Object.keys(dictionary);
for(var i = 0; i < keys.length;i++){
//keys[i] for key
//dictionary[keys[i]] for the value
}
빠르고 쉬운 방법은
Object.entries(event).forEach(k => {
console.log("properties ... ", k[0], k[1]); });
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/entries 설명서를 확인 하십시오.
swagger-ui.js 사용
당신은 이것을 할 수 있습니다-
_.forEach({ 'a': 1, 'b': 2 }, function(n, key) {
console.log(n, key);
});
아래 스크립트를 사용할 수 있습니다.
var obj={1:"a",2:"b",c:"3"};
for (var x=Object.keys(obj),i=0;i<x.length,key=x[i],value=obj[key];i++){
console.log(key,value);
}
출력
1 a
2 b
c 3
수락 된 답변을 개선하여 중첩을 줄이기 위해 대신 다음을 수행 할 수 있습니다.
for (var key in dictionary) {
if (!dictionary.hasOwnProperty(key)) {
continue;
}
console.log(key, dictionary[key]);
}
참고 URL : https://stackoverflow.com/questions/34913675/how-to-iterate-keys-values-in-javascript
'Programing' 카테고리의 다른 글
Base64를 사용하는 이유는 무엇입니까? (0) | 2020.04.12 |
---|---|
MySQL 한 테이블과 다른 테이블에서 모든 열을 선택하십시오. (0) | 2020.04.12 |
Java 8의 Optional.ifPresent 및 if-not-present의 기능적 스타일? (0) | 2020.04.12 |
HTML5 비디오가 끝났을 때 감지 (0) | 2020.04.12 |
pytest에서 예외가 발생했다고 올바르게 주장하는 방법은 무엇입니까? (0) | 2020.04.12 |