해결된 질문
작성
·
68
0
강의 내용중 12분 00초 정도에 나옵니다.
const filteredToDos = getFilterData();
리랜더링 될 때마다, 해당 함수를 호출하여 결과값을 저장하라는데,,,
이게 무슨말일까요 ???
답변 2
0
안녕하세요 이정환입니다.
리액트 컴포넌트는 함수입니다. 따라서 컴포넌트가 리렌더링된다는 것은 컴포넌트 역할을 하는 App, Home, List 등의 함수가 다시 실행된다는 것을 의미합니다.
8.5 챕터의 12분 경에는 List 함수(컴포넌트)내에 getFilteredData 라는 함수를 선언하고, 이 함수를 호출한 결과를 filteredTodos 변수에 저장하는 코드를 작성합니다.
그리고 이 모든 코드는 List 함수(컴포넌트) 내부에 선언되어 있으므로 List 컴포넌트가 리렌더링될 경우, 다시 말해 List 함수가 재 실행 될 경우 모두 다시 실행됩니다. 그 결과 getFilteredData 함수의 선언부터 호출까지 다시 이루어지게 됩니다.
강의의 "리렌더링 될 때 마다, getFitleredData 함수를 재 호출하여 결과값을 변수에 저장한다" 라는 말의 의미는 바로 이것입니다.
0
안녕하세요, 인프런 AI 인턴입니다. 정예은님.
질문하신 부분은 React 컴포넌트에서 상태 업데이트와 관련된 개념입니다. const filteredToDos = getFilterData();
는 컴포넌트가 리렌더링 될 때마다 getFilterData()
함수를 호출해서 그 결과를 filteredToDos
변수에 저장합니다. 여기에서 리렌더링은 React의 상태나 props가 변경될 때마다 자동으로 발생하는 과정입니다.
리렌더링: React 컴포넌트는 상태(state)나 속성(props)이 변경될 때마다 리렌더링됩니다. 이는 동일한 UI가 최신 상태를 반영하도록 도와줍니다.
getFilterData() 함수 호출: 이 함수는 현재 상태에 따라 특정 조건으로 데이터를 필터링하는 로직을 포함합니다. 리렌더링될 때마다 최신의 필터링된 데이터를 얻기 위해 호출됩니다.
효율적인 상태 업데이트: 필터링된 데이터는 변경된 상태에 따라 갱신되어야 하므로 리렌더링 시마다 함수를 호출하게 됩니다. 이렇게 하면 최신의 데이터 상태를 UI에 반영할 수 있습니다.
비슷한 주제에서 발생했던 이슈나 해결 방법을 참고하시면 더욱 명확한 이해에 도움이 될 수 있습니다. 아래 링크를 확인해보세요:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.