여기에서 객체와 검색 문자열을 가져와서 검색 문자열로 시작하여 객체를 반환하는 객체 키를 필터링하는 함수를 만들어야 합니다.
다음은 그렇게 하는 코드입니다 -
예시
const obj = {
"PHY": "Physics",
"MAT": "Mathematics",
"BIO": "Biology",
"COM": "Computer Science",
"SST": "Social Studies",
"SAN": "Sanskrit",
"ENG": "English",
"HIN": "Hindi",
"ESP": "Spanish",
"BST": "Business Studies",
"ECO": "Economics",
"CHE": "Chemistry",
"HIS": "History"
}
const str = 'en';
const returnFilteredObject = (obj, str) => {
const filteredObj = {};
Object.keys(obj).forEach(key => {
if(key.substr(0, str.length).toLowerCase() ===
str.toLowerCase()){
filteredObj[key] = obj[key];
}
});
return filteredObj;
};
console.log(returnFilteredObject(obj, str)); 코드 설명 -
우리는 단순히 객체의 각 키에 대해 반복합니다. 인수로 받은 str로 시작하면 다른 객체에 저장하고 그렇지 않으면 계속 반복합니다.
바로 이 문제의 목적을 위해 우리는 각 키를 반복하고 필요한 키를 새 개체에 넣었지만 더 성능이 좋은 솔루션을 위해서는 새 개체를 만드는 대신 원래 개체에서 원하지 않는 속성을 삭제할 수도 있었습니다.
출력
콘솔의 출력은 다음과 같습니다 -
{
ENG:"English"
}