useMemo Hook을 사용하면 이러한 작업을 최적화할 수 있습니다. 렌더링하는 과정에서 특정 값이 바뀌었을 때만 연산을 실행하고, 원하는 값이 바뀌지 않았다면 이전에 연산했던 결과를 다시 사용하는 방식입니다.

    코드를 다음과 같이 수정해 보세요.

    Average.js

    import React, { useState, useMemo } from 'react';
     
    const getAverage = numbers => {
      console.log('평균값 계산 ..');
      if (numbers.length === 0) return 0;
      const sum = numbers.reduce((a, b) => a + b);
      return sum / numbers.length;
    };
     
    const Average = () => {
      const [list, setList] = useState([]);
      const [number, setNumber] = useState('');
     
      const onChange = e => {
        setNumber(e.target.value);
      };
      const onInsert = () => {
        const nextList = list.concat(parseInt(number));
        setList(nextList);
        setNumber('');
      };
     
      const avg = useMemo(() => getAverage(list), [list]);
     
      return (
        <div>
          <input value={number} onChange={onChange} />
          <button onClick={onInsert}>등록</button>
          <ul>
            {list.map((value, index) => (
              <li key={index}>{value}</li>
            ))}
          </ul>
          <div>
            <b>평균값:</b> {avg}
          </div>
        </div>
      );
    };
     
    export default Average;

    신간 소식 구독하기
    뉴스레터에 가입하시고 이메일로 신간 소식을 받아 보세요.