inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

Slack 클론 코딩[실시간 채팅 with React]

커스텀 훅 만들기

useInput을 사용했을 때, 해당 값을 지우는 방법이 궁금합니다.

579

Sangmin Park

작성한 질문수 7

0

안녕하십니까. 선생님께서 만드신 useInput Custom Hooks를 팀 프로젝트에서 사용하던 중에 질문이 있어 글을 올립니다.

const [name, onChangeName] = useInput('')의 형태로 useInput 선언을 해줬습니다. 이 name과 password는 form 안에 들어가있습니다. 여기서 저는 form을 제출했을 때 이 name과 password의 값을 없애고 싶습니다. 그러니까 setName(''), setPassword('')을 하고 싶다는 것입니다. 헌데 이미 onChange={onChangeName}으로 걸어버려 어떻게 해야할 지 모르겠습니다.

아래에 제가 사용하려고 한 코드 일부를 첨부합니다. 감사합니다.

import React, { useState } from 'react';
import useInput from "../../Hooks/useInput";

const AddMenu = () => {
  let pwd = '1234';
  const [disabled, setDisabled] = useState(false);
  const [name, onChangeName] = useInput("");
  const [password, onChangePassword] = useInput("");
  const onSubmitForm = async (e) => {
    setDisabled(true);
    e.preventDefault();
    await new Promise((r) => setTimeout(r, 1000));
    if (pwd === password) {
       alert("등록되었습니다");
      setDisabled(false);
      setShowPopupMenu(false);
      // 이 부분에 name과 password input 값을 초기화해주고 싶습니다.
    } else {
      alert("비밀번호가 일치하지 않습니다");
      setDisabled(false);
    }
  }
            <FormWrap onSubmit={onSubmitForm}>
              <Input type="text" onChange={onChangeName} placeholder="상품명" />
              <Input type="password" onChange={onChangePassword} placeholder="관리자 비밀번호" />
           </FormWrap>
} 

const Input = styled.input`
  width: 183px;
  height: 32px;
  margin-bottom: 5px;
  background-color: #dedef7;
  box-shadow: inset 0px 3px 3px #aaa;
`;

const FormWrap = styled.form`
  margin-top: 15px;
  text-align: center;
`;

useInput.js입니다.

import { useCallback, useState } from "react";

const useInput = (initialData) => {
  const [value, setValue] = useState(initialData);
  const handler = useCallback((e) => {
    setValue(e.target.value);
  }, []);
  return [value, handler, setValue];
};

export default useInput;

babel Socket.io 웹팩 typescript react 클론코딩

답변 1

1

제로초(조현영)

onSubmit 안에서 set 두 개를 호출하시면 되지 않나요?

0

Sangmin Park

그냥 setName('')과 setPassword('')을 넣으라는 말씀이신가요?? 그렇게 하면   Line 42:7:  'setName' is not defined  no-undef 라는 오류가 발생합니다.

0

제로초(조현영)

const [name, onChangeName, setName] = useInput('') 하셔야죠.

0

Sangmin Park

아 ....!!! 그러네요. 감사합니다!

기본 셋팅과 관련하여

0

106

1

초기 셋팅 back과 front만 남겨두고 다 지운 후 진행 방법

0

109

2

focus 시에만 화면 업데이트 되는 이유 + 해결방법

0

165

2

useEffect 개수 관리

0

122

2

라이브러리 서치 방법

0

118

2

함수 정의 패턴

0

80

1

npm run dev 에러

0

156

3

npx webpack 후 에러

0

187

2

'void' 형식 식의 truthiness를 테스트할 수 없습니다.ts(1345)

0

151

2

사용자 가입시 에러발생 (TypeError: Cannot read properties of null (reading 'addMembers')

1

191

2

초기세팅중 packge.json 에러떠요

0

162

2

CORS - Access-Control-Allow-Origin 누락 문제

0

439

3

로그인 페이지 무한 새로고침 현상

0

608

2

Module not found: Error: Can't resolve './App' 에러

0

970

1

배포 방법

0

306

2

npm run dev 시 빌드가 매우 느려졌습니다

0

1010

2

alias 경로 설정 오류

0

460

2

fetcher 함수의 data 값이 두번 찍히는 이유

0

282

1

제네릭 질문

0

225

2

ts-node 대신 tsx 사용여부

0

377

1

배포 관련 질문

0

249

1

[nginx + https] 서비스를 실행하면 niginx가 아닌 서비스 화면을 보여주게 하고 싶습니다.

0

395

2

[배포하기] webpack에 aws 퍼블릭 IPv4 주소 와 포트 주소를 작성하고 나서 빌드후 실행하면 오류가 발생합니다.

0

341

1

users 호출 시 쿠키가 담기지 않는 이슈 질문드립니다.

0

252

2