TIL 29 | JavaScript replit 30. Object(3)

ym j·2021년 4월 18일
0

JavaScript

목록 보기
4/7
post-thumbnail

JavaScript replit 30

Assignment

아래 설명을 읽고 getExamResult 함수를 구현하세요.

인자 scores 는 다음과 같은 객체입니다. 객체의 요소의 갯수 및 키의 이름들은 달라질 수 있습니다. 객체의 값은 다음 9가지 문자열 중에서 하나를 가지고 있습니다.

  • 'A+', 'A', 'B+', 'B', 'C+', 'C', 'D+', 'D', 'F'
{
  '생활속의회계': 'C',
  '논리적글쓰기': 'B',
  '독일문화의이해': 'B+',
  '기초수학': 'D+',
  '영어회화': 'C+',
  '인지발달심리학': 'A+',
}

인자 requiredClasses 는 다음과 같이 문자열로 된 배열입니다.

['영어회화', '기초수학', '공학수학', '컴퓨터과학개론']

다음 조건을 만족하는 객체를 리턴하도록 함수를 구현해주세요.
1. scores 객체가 가지고 있는 키들은 새로운 객체에 포함되어야 합니다. 단, 그 값들은 다음 원리에 따라 숫자로 바뀌어 할당되어야 합니다.

- A+ => 4.5
- A => 4
- B+ => 3.5
- B => 3
- C+ => 2.5
- C => 2
- D+ => 1.5
- D => 1
- F => 0
  1. requiredClasses 배열의 요소로는 존재하지만, scores의 키로는 존재하지 않는 항목이 있다면, 해당 요소는 새로운 객체의 키가 되고, 값으로 0을 가져야 합니다. 위에서 예시로 묘사된 객체와 배열이 인자로 들어왔다면, 다음과 같은 객체과 리턴됩니다. 요소간 순서는 다를수 있지만, 채점에 무관합니다.
    {
      '생활속의회계': 2,
      '논리적글쓰기': 3,
      '독일문화의이해': 3.5,
      '기초수학': 1.5,
      '영어회화': 2.5,
      '인지발달심리학': 4.5,
      '공학수학': 0,
      '컴퓨터과학개론': 0,
    }


Code

const getExamResult = (scores, requiredClasses) => {
    const result = {};
    //학점별 점수
    const scoresToNumber = {
        "A+": 4.5,
        "A": 4,
        "B+": 3.5,
        "B": 3,
        "C+": 2.5,
        "C": 2,
        "D+": 1.5,
        "D": 1,
        "F": 0,
    }
    //requiredClasses의 요소들을 result의 객체의 key로, value는 0으로 초기화
    for (const key of requiredClasses) {
        result[key] = 0;
    }
    for (const keyInScores in scores) {
        const scores_value = scores[keyInScores]; //scores의 value  (알파벳  학점)
        const scoresToNumber_value = scoresToNumber[scores_value]; //scoresToNumber의 value(숫자 학점)
        console.log(scoresToNumber_value);
        result[keyInScores] = scoresToNumber_value // 
    }
    return result;
}
  • 처음 접근할 당시, scoreToNumber부분을 switch로 접근하였으나, 너무 지저분해지는 관계로 위와 같이 객체의 키를 변수로 접근하는 computer properties 을 통해 코드를 작성했다.

  • JavaScript replit 21에서 느낀 것처럼,console.log()를 찍어 일일이 확인하는 것에 대한 중요성을 다시금 느낄 수 있었다.

profile
블로그를 이전하였습니다 => "https://jymini.tistory.com"

0개의 댓글