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

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Dorothy_YANG

With Dorothy

🤯TIL/React

[한입 크기로 잘라 먹는 리액트] React에서 배열 사용하기 4 - 데이터 수정하기

2023. 11. 19. 19:07
728x90

1. onDelete > onRemove로 변수명 변경

2. DiaryItem.js에 수정하기 버튼 추가

 


DiaryItem.js

- 수정하기 버튼 추가

- 삭제하기 버튼 onClick 함수를 handleRemove로 빼서 정리

- state 생성

- 토글함수 생성 : isEdit이 true면 수정중이라고 간주 > content부분에 수정폼 띄우기

- 토글 상태(T/F)에 따른 버튼 기능 수정

- 수정 취소 후 다시 수정클릭 시 내용 원본 복구

- 수정완료 후 기능 추가

import { useRef, useState } from "react";

const DiaryItem = ({
  author,
  content,
  emotion,
  created_date,
  id,
  onRemove,
  onEdit,
}) => {
  const [isEdit, setIsEdit] = useState(false);
  const togleIsEdit = () => setIsEdit(!isEdit);

  const [localContent, setLocalContent] = useState(content);
  const localContentInput = useRef();

  const handleRemove = () => {
    if (window.confirm(`${id}번째 일기를 삭제하시겠습니까?`)) {
      onRemove(id);
    }
  };

  const handleQuitEdit = () => {
    setIsEdit(false);
    setLocalContent(content);
  };

  const handleEdit = () => {
    if (localContent.length < 5) {
      localContentInput.current.focus();
      return;
    }
    if (window.confirm(`${id}번째 일기를 수정하시겠습니까?`)) {
      onEdit(id, localContent);
      togleIsEdit();
    }
  };

  return (
    <div className="DiaryItem">
      <div className="info">
        <span>
          작성자 : {author} | 감정점수 : {emotion}
        </span>
        <br />
        <span className="date">{new Date(created_date).toLocaleString()}</span>
      </div>
      <div className="content">
        {isEdit ? (
          <>
            <textarea
              ref={localContentInput}
              value={localContent}
              onChange={(e) => setLocalContent(e.target.value)}
            />
          </>
        ) : (
          <>{content}</>
        )}
      </div>
      {isEdit ? (
        <>
          <button onClick={handleQuitEdit}>수정 취소</button>
          <button onClick={handleEdit}>수정 완료</button>
        </>
      ) : (
        <>
          <button onClick={handleRemove}>삭제하기</button>
          <button onClick={togleIsEdit}>수정하기</button>
        </>
      )}
    </div>
  );
};

export default DiaryItem;

App.js

- 수정하기 기능 추가 onEdit

import { useState, useRef } from "react";
import "./App.css";
import DiaryEditor from "./DiaryEditor";
import DiaryList from "./DiaryList";

// const dummyList = [...

function App() {
  const [data, setData] = useState([]);

  const dataId = useRef(0);

  const onCreate = (author, content, emotion) => {
    const created_date = new Date().getTime();

    const newItem = {
      author,
      content,
      emotion,
      created_date,
      id: dataId.current,
    };
    dataId.current += 1;
    setData([newItem, ...data]);
  };

  const onRemove = (targetId) => {
    console.log(`${targetId}가 삭제되었습니다.`);
    const newDiaryList = data.filter((it) => it.id !== targetId);
    setData(newDiaryList);
  };

  const onEdit = (targetId, newContent) => {
    setData(
      data.map((it) =>
        it.id === targetId ? { ...it, content: newContent } : it
      )
    );
  };

  return (
    <div className="App">
      <DiaryEditor onCreate={onCreate} />
      <DiaryList onRemove={onRemove} diaryList={data} onEdit={onEdit} />
    </div>
  );
}

export default App;

 


DiaryList.js

- onEdit 함수 props로 전달

import DiaryItem from "./DiaryItem";

const DiaryList = ({ diaryList, onRemove, onEdit }) => {
  return (
    <div className="DiaryList">
      <div>{diaryList.length}개의 일기가 있습니다.</div>
      <div>
        {diaryList.map((it) => (
          <DiaryItem key={it.id} {...it} onRemove={onRemove} onEdit={onEdit} />
        ))}
      </div>
    </div>
  );
};

DiaryList.defaultProps = {
  diaryList: [],
};

export default DiaryList;


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

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

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

www.inflearn.com

 

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

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

[한입 크기로 잘라 먹는 리액트] React에서 API 호출하기  (0) 2023.11.19
[한입 크기로 잘라 먹는 리액트] React Lifecycle 제어하기 - useEffect  (1) 2023.11.19
[한입 크기로 잘라 먹는 리액트] React에서 배열 사용하기 3 - 데이터 삭제하기  (0) 2023.11.19
[한입 크기로 잘라 먹는 리액트] React에서 배열 사용하기 2 - 데이터 추가하기  (0) 2023.11.19
[한입 크기로 잘라 먹는 리액트] React에서 배열 사용하기 1 - 리스트 렌더링 (조회)  (2) 2023.11.19
    '🤯TIL/React' 카테고리의 다른 글
    • [한입 크기로 잘라 먹는 리액트] React에서 API 호출하기
    • [한입 크기로 잘라 먹는 리액트] React Lifecycle 제어하기 - useEffect
    • [한입 크기로 잘라 먹는 리액트] React에서 배열 사용하기 3 - 데이터 삭제하기
    • [한입 크기로 잘라 먹는 리액트] React에서 배열 사용하기 2 - 데이터 추가하기
    Dorothy_YANG
    Dorothy_YANG
    Slowly but Surely, 비전공 문과생의 개발공부

    티스토리툴바