아래와 같이 객체 배열이 있습니다.
Object {Results:Array[2]}
Results:Array[2]
[0-1]
0:Object
id=1
name: "Rick"
1:Object
id=2
name:'david'
이 개체 배열의 각 요소에 Active라는 속성을 하나 더 추가하고 싶습니다.
최종 결과는 다음과 같습니다.
Object {Results:Array[2]}
Results:Array[2]
[0-1]
0:Object
id=1
name: "Rick"
Active: "false"
1:Object
id=2
name:'david'
Active: "false"
누군가이 이것을 달성하는 방법을 알려주십시오.
답변
forEach
메서드를 사용 하여 배열의 각 요소에 대해 제공된 함수를 한 번씩 실행할 수 있습니다 . 이 제공된 함수 Active
에서 요소에 속성을 추가 할 수 있습니다 .
Results.forEach(function (element) {
element.Active = "false";
});
답변
또는 사용 map
Results.map(obj=> ({ ...obj, Active: 'false' }))
원본을 변경하지 않고 각각에 대해 새 개체를 반환하도록 @adrianolsk의 주석을 반영하도록 편집되었습니다.
답변
Object.defineProperty(Results, "Active", {value : 'true',
writable : true,
enumerable : true,
configurable : true});
답변
나는이 문제에 대해서도 생각해 냈고, 그것을 해결하기 위해 내 앱을 실행하는 크롬 탭을 계속 충돌시켰다. 객체에 대한 스프레드 연산자 처럼 보입니다. 범인이었다.
adrianolsk의 의견과 위의 sidonaldson의 답변에서 약간의 도움을 받아 다음과 같이 바벨의 스프레드 연산자 출력 인 Object.assign ()을 사용했습니다 .
this.options.map(option => {
// New properties to be added
const newPropsObj = {
newkey1:value1,
newkey2:value2
};
// Assign new properties and return
return Object.assign(option, newPropsObj);
});
답변
키-값 구조로 객체를 통과합니다. 그런 다음 ‘Active’라는 새 속성과이 속성에 대한 샘플 값 ( ‘Active)을이 개체 내부의 모든 단일 개체에 추가합니다. 이 코드는 객체의 배열과 객체의 객체 모두에 적용될 수 있습니다.
Object.keys(Results).forEach(function (key){
Object.defineProperty(Results[key], "Active", { value: "the appropriate value"});
});
답변
ES6를 사용하면 간단하게 다음을 수행 할 수 있습니다.
for(const element of Results) {
element.Active = "false";
}
답변
