Dorothy_YANG
With Dorothy
Dorothy_YANG
전체 방문자
오늘
어제
  • 분류 전체보기 (279)
    • Hi, I'm Dorothy 🕵️‍♂️ (21)
      • Slowly but Surely (18)
      • IT certifications (3)
    • 🤯TIL (80)
      • HTML & CSS (2)
      • Javascript & jQuery (13)
      • React (13)
      • C언어 (1)
      • JAVA (22)
      • Python (2)
      • Oracle SQL (10)
      • My SQL (5)
      • Spring (12)
    • 💻Programmers (17)
    • 🏫 Open API_JAVA (101)
    • 🌎 Project (10)
      • Shopping (10)
    • 💥 Error (24)
    • ⚙ Setting (23)

블로그 메뉴

  • 홈
  • 방명록

공지사항

인기 글

태그

  • SQLD합격
  • SQLD합격후기
  • 파이썬온라인
  • Database
  • colaboratory
  • 기간쿼리
  • 오류해결
  • 창초기화
  • CSS
  • 백준
  • 연습문제
  • Javascript
  • 독학후기
  • 노마드코더
  • java
  • 서버등록
  • 시작일종료일
  • 콜라보레이토리
  • googlecolaboratory
  • SQL
  • 기간설정
  • spring
  • oracle
  • HTML
  • sql기간
  • 코딩앙마
  • AllArgsConstructor
  • 비쥬얼스튜디오코드
  • Eclipse
  • 이것이자바다

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Dorothy_YANG
🤯TIL/React

[한입 크기로 잘라 먹는 리액트] React에서 DOM 조작하기 - useRef

🤯TIL/React

[한입 크기로 잘라 먹는 리액트] React에서 DOM 조작하기 - useRef

2023. 11. 17. 20:01
728x90

1. handleSubmit에 조건문, focus문 추가

2. DOM에 접근하는 useRef() 사용

 

DiaryEditor.js

import { useRef, useState } from "react";
const DiaryEditor = () => {
const authorInput = useRef();
const contentInput = useRef();
const [state, setState] = useState({
author: "",
content: "",
emotion: 1,
});
const handleChangeState = (e) => {
setState({
...state,
[e.target.name]: e.target.value,
});
};
const handleSubmit = () => {
if (state.author.length < 1) {
alert("작성자는 최소 1글자 이상 입력해주세요.");
authorInput.current.focus();
// focus
return; // 더이상 출력 안되도록 막기
}
if (state.content.length < 5) {
alert("일기 본문은 최소 5글자 이상 입력해주세요.");
contentInput.current.focus();
// focus
return;
}
console.log(state);
alert("저장 성공");
};
return (
<div className="DiaryEditor">
<h2>오늘의 일기</h2>
<div>
<input
ref={authorInput}
name="author"
value={state.author}
onChange={handleChangeState}
/>
</div>
<div>
<textarea
ref={contentInput}
name="content"
value={state.content}
onChange={handleChangeState}
/>
</div>
<div>
<span>오늘의 감정점수 : </span>
<select
name="emotion"
value={state.emotion}
onChange={handleChangeState}
>
<option value={1}>1</option>
<option value={2}>2</option>
<option value={3}>3</option>
<option value={4}>4</option>
<option value={5}>5</option>
</select>
</div>
<div>
<button onClick={handleSubmit}>일기 저장하기</button>
</div>
</div>
);
};
export default DiaryEditor;

 

 


  • 출처
    https://inf.run/N9fZn
 

한입 크기로 잘라 먹는 리액트(React.js) : 기초부터 실전까지 - 인프런 | 강의

개념부터 독특한 프로젝트까지 함께 다뤄보며 자바스크립트와 리액트를 이 강의로 한 번에 끝내요. 학습은 짧게, 응용은 길게 17시간 분량의 All-in-one 강의!, 리액트, 한 강의로 끝장낼 수 있어요.

www.inflearn.com

 

728x90
저작자표시 비영리 변경금지 (새창열림)

'🤯TIL > React' 카테고리의 다른 글

[한입 크기로 잘라 먹는 리액트] React에서 배열 사용하기 2 - 데이터 추가하기  (0) 2023.11.19
[한입 크기로 잘라 먹는 리액트] React에서 배열 사용하기 1 - 리스트 렌더링 (조회)  (2) 2023.11.19
[한입 크기로 잘라 먹는 리액트] React에서 사용자 입력 처리하기  (0) 2023.11.17
[React vs JavaScript] React란?  (0) 2023.11.04
[코딩앙마] 영어 단어장 CRUD_v6기준  (0) 2023.07.31
    '🤯TIL/React' 카테고리의 다른 글
    • [한입 크기로 잘라 먹는 리액트] React에서 배열 사용하기 2 - 데이터 추가하기
    • [한입 크기로 잘라 먹는 리액트] React에서 배열 사용하기 1 - 리스트 렌더링 (조회)
    • [한입 크기로 잘라 먹는 리액트] React에서 사용자 입력 처리하기
    • [React vs JavaScript] React란?
    Dorothy_YANG
    Dorothy_YANG
    Slowly but Surely, 비전공 문과생의 개발공부

    티스토리툴바

    개인정보

    • 티스토리 홈
    • 포럼
    • 로그인

    단축키

    내 블로그

    내 블로그 - 관리자 홈 전환
    Q
    Q
    새 글 쓰기
    W
    W

    블로그 게시글

    글 수정 (권한 있는 경우)
    E
    E
    댓글 영역으로 이동
    C
    C

    모든 영역

    이 페이지의 URL 복사
    S
    S
    맨 위로 이동
    T
    T
    티스토리 홈 이동
    H
    H
    단축키 안내
    Shift + /
    ⇧ + /

    * 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.