본문 바로가기
모던 리액트

6. input 상태 관리

by 슈퍼 루키 2023. 1. 18.

input 태그의 value 값도 설정해주는 것이 중요 -> 상태가 바뀌었을 때 input 내용도 업데이트

 

InputSample.js

import React, { useState } from 'react';

function InputSample() {
  const [text, setText] = useState('');

  const onChange = (e) => {
    setText(e.target.value);
  };

  const onReset = () => {
    setText('');
  };

  return (
    <div>
      <input onChange={onChange} value={text}  />
      <button onClick={onReset}>초기화</button>
      <div>
        <b>값: {text}</b>
      </div>
    </div>
  );
}

export default InputSample;

 

여러개의 input 상태 관리하기

- 여러개의 useState와 onChange로 구현하는 것보다 input에 name 설정 => 이벤트가 발생했을 때 이 값을 참조하고

useState에 객체 형태의 상태 관리가 더 좋은 방법

- 리액트에서 객체를 업데이트할 때에는 기존 객체를 직접수정하면 안되고, 새로운 객체를 만들어서 새 객체에 변화를 주어야함

- spread 문법인 ... 문법을 사용해 기존 객체를 복사함 => 불변성을 지킨다

- 불변성을 지켜주어야 리액트 컴포넌트에서 상태가 업데이트 됐음을 감지하고 이에 따라 필요한 리렌더링이 되고

컴포넌트 업데이트 성능 최적화를 제대로 할 수 있음

 

InputSample.js

import React, { useState } from 'react';

function InputSample() {
  const [inputs, setInputs] = useState({
    name: '',
    nickname: ''
  });

  const { name, nickname } = inputs; // 비구조화 할당을 통해 값 추출

  const onChange = (e) => {
    const { value, name } = e.target; // 우선 e.target 에서 name 과 value 를 추출
    setInputs({
      ...inputs, // 기존의 input 객체를 복사한 뒤
      [name]: value // name 키를 가진 값을 value 로 설정
    });
  };

  const onReset = () => {
    setInputs({
      name: '',
      nickname: '',
    })
  };


  return (
    <div>
      <input name="name" placeholder="이름" onChange={onChange} value={name} />
      <input name="nickname" placeholder="닉네임" onChange={onChange} value={nickname}/>
      <button onClick={onReset}>초기화</button>
      <div>
        <b>값: </b>
        {name} ({nickname})
      </div>
    </div>
  );
}

export default InputSample;
반응형

'모던 리액트' 카테고리의 다른 글

react onkeydown에서 preventDefault 에러  (1) 2023.02.01
5. useState  (0) 2023.01.18
4. 조건부 렌더링  (0) 2023.01.18
3. props  (0) 2023.01.18
2. JSX  (0) 2023.01.18

댓글