• 로그인
  • 장바구니에 상품이 없습니다.

home2 게시판 Next.js 게시판 글 수정기능 관련 문제

글 수정기능 관련 문제

4 글 보임 - 1 에서 4 까지 (총 4 중에서)
  • 글쓴이
  • #95698

    최현수
    참가자
    src/app/list/page.js
    import Link from "next/link";
    import { connectDB } from "../../../util/database";
    import DetailLink from "./DetailLink";
    export default async function List() {
      // db 데이터 가져오기
      const db = (await connectDB).db("forum");
      let result = await db.collection("post").find().toArray();
      console.log(result);
      return (
        <div className="list-bg">
          {result.map((a, i) => {
            return (
              <div className="list-item">
                <Link href={"/detail/" + result[i]._id}>
                  <h4>{result[i].title}</h4>
                </Link>
                <p>{result[i].content}</p>
                {/* <DetailLink /> */}
                <Link href={"/edit/" + result[i]._id} className="list-btn">
                  수정하기✏️
                </Link>
              </div>
            );
          })}
        </div>
      );
    }
    
    
    src/app/edit/[id]/page.js
    
    
    import { connectDB } from "../../../../util/database";
    import { ObjectId } from "mongodb";
    export default async function Edit(props) {
      const db = (await connectDB).db("forum");
      let result = await db
        .collection("post")
        .findOne({ _id: new ObjectId(props.params.id) });
      return (
        <div className="p-20">
          <h4>수정페이지</h4>
          <form action="/api/edit" method="POST">
            <input name="title" value={result.title} />
            <input name="content" value={result.content} />
            <input
              style={{ display: "none" }}
              name="_id"
              value={result._id.toString()}
            />
            <button type="submit">수정하기</button>
          </form>
        </div>
      );
    }
    
    src/app/api/new-post/route.js
    
    import { NextResponse } from "next/server";
    import { redirect } from "next/navigation";
    import { connectDB } from "../../../../util/database";
    export async function POST(req) {
      const formData = await req.formData();
      const title = formData.get("title");
      const content = formData.get("content");
      const db = (await connectDB).db("forum");
      const post = { title, content };
      await db.collection("post").insertOne(post);
      redirect("/list");
    }
     
    src/app/api/edit/route.js
    import { connectDB } from "../../../../util/database";
    import { ObjectId } from "mongodb";
    export async function POST(req, res) {
      const formData = await req.formData();
      const title = formData.get("title");
      const content = formData.get("content");
      const db = (await connectDB).db("forum");
      const updatePost = { title, content };
      let result = await db
        .collection("post")
        .updateOne({ _id: new ObjectId(req.body._id) }, { $set: updatePost });
      console.log(result);
      return NextResponse.json({ updatePost });
    }
     
    현재 글 작성하고 리다이렉트가 되지않는문제와 게시물이 아예 지워지지않는 고유값처럼
    수정되지않는 문제가 발생합니다.
    
    
    다른 버전으로 해보려고 하니까 많이 힘드네요...도와주십쇼..
    #95703

    codingapple
    키 마스터
    redirect는 이런거 쓰라는군요 https://nextjs.org/docs/app/api-reference/functions/next-response#redirect
    db에 있는게 수정안되는건 _id가 틀리거나 오타있는게 아닐까요
    #95712

    최현수
    참가자
    아예 글이 지우거나 뭘 더 쓰거나 하는 게 안됩니다
    
    디폴트값처럼 딱 박혀서 수정자체가 안되서..일단 다시 좀 해보겠습니다.. 감사합니다
     
    #95722

    codingapple
    키 마스터
    input태그에 value말고 defaultValue="" 로 넣어봅시다
4 글 보임 - 1 에서 4 까지 (총 4 중에서)
  • 답변은 로그인 후 가능합니다.

About

현재 월 700명 신규수강중입니다.

  (09:00~20:00) 빠른 상담은 카톡 플러스친구 코딩애플 (링크)
  admin@codingapple.com
  이용약관
ⓒ Codingapple, 강의 예제, 영상 복제 금지
top

© Codingapple, All rights reserved. 슈퍼로켓 에듀케이션 / 서울특별시 강동구 고덕로 19길 30 / 사업자등록번호 : 212-26-14752 온라인 교육학원업 / 통신판매업신고번호 : 제 2017-서울강동-0002 호 / 개인정보관리자 : 박종흠