씨네
공부하는 개발자 강씨네
씨네
  • 분류 전체보기 (460)
    • Web (21)
      • HTML (11)
      • CSS (10)
    • JS 관련 (49)
      • JavaScript (27)
      • JQuery (22)
    • TS 관련 (15)
      • TypeScript (15)
    • NodeJS (7)
      • NodeJS (7)
    • 따라하며 배우는 시리즈 (23)
      • NodeJS & ReactJS Basic (23)
      • NodeJS & ReactJS Movie (0)
      • NodeJS & ReactJS Youtube (0)
      • NodeJS & ReactJS ChatBot (0)
    • SPA (14)
      • React (14)
      • Vue (0)
      • Anguler (0)
    • Java 관련 (118)
      • Java (52)
      • JDBC (6)
      • JSP & Servlet (18)
      • Spring Legecy (38)
      • SpringBoot (4)
    • Python (26)
      • Python (20)
      • PyMongo (1)
      • Django (5)
    • Git (24)
      • Github (24)
    • RDB (22)
      • Oracle (21)
      • MySQL (1)
    • NoSQL (5)
      • MongoDB (5)
    • OS (4)
      • Linux (4)
    • 빅데이터 (2)
      • hadoop (2)
    • IDE (20)
      • eclipse (11)
      • VSCODE (4)
      • VisualStudio (1)
      • IntelliJ (1)
      • PyCharm (1)
      • DBeaver (2)
    • Install (3)
      • Tomcat (1)
      • Docker (1)
      • Anaconda (1)
    • 오류&에러 (28)
      • TS (2)
      • NodeJS (7)
      • SQL (8)
      • Java (1)
      • Spring (4)
      • Git (6)
      • 기타 (0)
    • 알고리즘 (67)
      • 수열 (1)
      • 백준(backjoon) (39)
      • Programmers (27)
    • 자격증 (5)
      • SQLD (5)
    • 기타 (2)
    • IT유튜브로 지식쌓기 (2)

공지사항

인기 글

최근 글

티스토리

250x250
hELLO · Designed By 정상우.
씨네

공부하는 개발자 강씨네

[React] 게임으로 배우는 리액트 - Fragment, setState
SPA/React

[React] 게임으로 배우는 리액트 - Fragment, setState

2022. 5. 27. 11:41
728x90

render(){
    return (
        <div>
            <div>{this.state.first}곱하기{this.state.second}는?</div>
                <form onSubmit={this.onSubmit}>
                    <input type="number" value={this.state.value} onChange={this.onChange}/>
                    <button>입력!</button>
                </form>
                <div>{this.state.result}</div>
            </div>
    );
}

앞선 포스팅의 구구단 게임 만들기에서 render부분입니다.

해당 코드에서 필요없는 div로 감싸져 있습니다.

이 div가 없으면 에러가 발생하는데요.

과거에는 리액트의 단점이라고 할수 있겠습니다.

해당 div가 있으면 css를 적용할때도 번거롭고 불편할수 있는데요.

이 부분이 보완되었습니다.

​

div 대신 React.Fragment를 작성해주면 됩니다.

불필요한 div영역은 사라지도 에러도 발생하지 않습니다.

​


​

onSubmit = (e) => {
    e.preventDefault();
    if(parseInt(this.state.value) === this.state.first * this.state.second){
        this.setState({
            result: '정답 : ' + this.state.value,
            first: Math.ceil(Math.random() * 9),
            second: Math.ceil(Math.random() * 9),
            value: '',
        });
    } else {
        this.setState({
            result: '떙',
            value: '',
        });
    }
};

해당 코드에서는 if문에서 result는 바뀌기 이전의 상태를 나머지는 바뀐 이후의 상태를 나타내주는 코드인데 이렇게 보시면 조금 헷갈리시죠??

​

prevState를 이용하면 이전 상태를 나타내줄수 있습니다.

728x90

'SPA > React' 카테고리의 다른 글

[React] 게임으로 배우는 리액트 - Hooks  (0) 2022.05.29
[React] 게임으로 배우는 리액트 - ref로 초점맞추기  (0) 2022.05.28
[React] 게임으로 배우는 리액트 - 구구단게임 만들기  (0) 2022.05.26
[React] 게임으로 배우는 리액트 - 바벨(babel)  (0) 2022.05.25
[React] 게임으로 배우는 리액트 - 기본 문법(class, state, render())  (0) 2022.05.24
    'SPA/React' 카테고리의 다른 글
    • [React] 게임으로 배우는 리액트 - Hooks
    • [React] 게임으로 배우는 리액트 - ref로 초점맞추기
    • [React] 게임으로 배우는 리액트 - 구구단게임 만들기
    • [React] 게임으로 배우는 리액트 - 바벨(babel)
    씨네
    씨네
    개발자 씨네가 공부하는 내용을 기록 겸 공유하는 블로그입니다!

    티스토리툴바