반응형
✔️ 필요성
파일을 업로드하는 Input 태그에서 제출 버튼을 눌렀는데도 해당 파일 이름이 그대로 남아있는 경우가 있다.
제출 버튼을 누르면 파일이름이 초기화(없어지면)되기를 원한다.
data:image/s3,"s3://crabby-images/dbbf2/dbbf2f3725b9a5c82029c918703090acafe718ff" alt=""
✔️ 문제 확인
useRef를 선택해서 reference 객체를 만들어주고 해당 객체를 input 태그의 ref props에 지정한다.
그리고 제출버튼을 눌렀을 때 ref객체를 초기화하는 onClearInput 함수를 호출한다
// Image Input 값을 초기화
const inputImageRef = useRef<any>(null)
const onClearInput = () => {
inputImageRef.current.value = ''
}
// feedback 제출버튼을 클릭했을 때
const onClick = async () => {
try {
alert('피드백 전송을 성공했습니다.')
} catch (e) {
alert('피드백 전송에 실패했습니다.')
} finally {
onClearInput()
}
}
return (
<>
<input
type={'file'}
accept={'image/*'}
onChange={handleFileInput}
ref={inputRef}
/>
<button onClick={onClick}/>
</>
)
✔️ 문제 해결
제출하기 버튼을 눌렀을 때 '선택된 파일 없음'으로 다시 바뀐다
data:image/s3,"s3://crabby-images/dbbf2/dbbf2f3725b9a5c82029c918703090acafe718ff" alt=""
반응형
'프론트엔드 웹 > React' 카테고리의 다른 글
REACT 웹에서 S3로 이미지 올리기 (3) _ React code (0) | 2022.06.21 |
---|---|
REACT 웹에서 S3로 이미지 올리기 (2) _ IAM 권한 설정하기 (0) | 2022.06.21 |
REACT 웹에서 S3로 이미지 올리기 (1) _ S3 Bucket 만들기 (0) | 2022.06.17 |
React 18 useEffect render twice (0) | 2022.05.12 |
tmap api ref.current.destroy is not a function (0) | 2022.05.03 |