inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

한 입 크기로 잘라 먹는 리액트(React.js) : 기초부터 실전까지

8.2) UI 구현하기

setState관련

315

김동훈

작성한 질문수 3

0

20분경 나온 setState관련해서 미리 코드를 짜보았었는데용

 <div className="DiaryEditor">
            <h2>오늘의 일기</h2>
            <div>
                <input
                    value={state.author}
                    onChange={(e) => {
                        setState(e.target.value);
                    }}
                />
            </div>
            <div>
                <textarea
                    value={state.content}
                    onChange={(e) => {
                        setState(e.target.value);
                    }}
                    placeholder="내용을 입력해주세요"
                />
            </div>
        </div>

이렇게 짜도 정상적으로 작동이 되는데 더 깊이 들어가서 문제가 생기는 경우일까요??

javascript react node.js

답변 1

0

이정환 Winterlood

안녕하세요 이정환입니다.

질문 주신 대로 코드를 작성하면 제대로 State가 업데이트 되지 않습니다.

그 이유는 input과 textarea에 사용자가 특정 텍스트 예를 들면 "a"를 입력해 onChange 이벤트가 발생하게 되면 setState 함수가 호출되면서 입력한 값을 그대로 새로운 State 의 값으로 변경시켜버리게 되는데요

그럼 state의 값이 onChange 이벤트 이후에는 객체가 아닌 문자열로 변경되기 때문에 state.author, state.content 등의 프로퍼티에 접근할 수 없게 됩니다.

존재하지 않는 일기 url입력 시 alert이 두 번 떠요

0

24

1

교재(3쇄)와 강의 내용 문의

0

31

2

12.13) 하단 여백 스타일링 관련 질문 드립니다.

0

65

2

에러 질문드립니다

0

63

2

VSCode 설정 문의

0

67

2

PPT 코드 관련 질문

0

49

2

useEffect와 lifecycle문의

0

63

2

프론트엔드 학습 수준 문의

0

77

2

리액트 챕터별 코드에서 eslint 설정파일이 없어요

0

69

2

데이터 로딩중 화면만 계속 나와요!!

0

72

2

퍼블리셔일경우 어느정도 수준까지 강의를 들어야할까요

0

100

2

이후의 커리큘럼 문의

0

125

2

실슬환경 설정에서 save후 console.log 부분이 새로고침이 안되는현상입니다.

0

72

2

최적화 관련 질문있습니다 (useMemo 등)

0

103

3

프로바이더 컴포넌트의 위치는 어떤 기준인가요?

1

95

3

Date 객체에 관련하여 질문드립니다.

0

96

2

리액트 개정판 교재 질문

0

76

2

예제코드가 안나와요!

0

86

2

select a variant 선택에서 javascript와 javascript+react compiler 중 무엇을 선택해야하나요? com

0

130

2

onMouseEnter 관련 문의 드립니다

0

110

3

배열의 렌더링 관련 질문 드립니다.

0

82

2

2:40초 refObj를 콘솔로 출력시 오류가 발생합니다.

0

129

2

TS, 리액트 강의중에 뭘 먼저 수강하는게 좋을까요?

0

150

2

useCallback 적용한 onCreate, onUpdate, onDelete 함수..

0

73

1