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

home2 게시판 Next.js 게시판 삭제기능 강의들으면서 코드짰는데 오류나요

삭제기능 강의들으면서 코드짰는데 오류나요

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

    양성호
    참가자
    Unhandled Runtime Error
    SyntaxError: "undefined" is not valid JSON
    Call Stack
    JSON.parse
    이게 오류내용이고
    강의대로 코드 짰고 오류 못찾겠어서 질문드립니다
    
    [[[list/ListItem.js]]]
    
    
    'use client';
    import Link from "next/link"
    export default async function ListItem({result}){  
      return (
        <div>
          { result.map((a, i)=>
              <div className="list-item" key = {i}>
                <Link href={'/detail/' + result[i]._id}>{result[i].title}</Link>
                <Link href={'/edit/' + result[i]._id} className="list-btn">수정</Link>
                <span onClick={()=>{
                  fetch('/api/post/delete', {method : 'DELETE', body : result[i]._id})
                  .then(()=>{
                    console.log(123123)
                  })
                }}>삭제</span>
                <p>1월 1일</p>
              </div>
            )}    
        </div>
      )
    }
    
    
    [[[list/page.js]]]
    
    
    import { connectDB } from "@/util/database.js"
    import Link from "next/link";
    import ListItem from "./ListItem.js"
    export default async function List() {
      let db = (await connectDB).db('forum')
      let result = await db.collection('post').find().toArray()
      return (
        <div className="list-bg">
          <ListItem result={result}/>
        </div>
      )
    }
    
    
    [[[post/detete.js]]]
    
    
    
    import { connectDB } from "@/util/database";
    export default async function handler(요청, 응답){
      if (요청.method == 'DELETE'){
        
        let db = (await connectDB).db('forum')
        let result = await db.collection('post').deleteOne({ _id : new ObjectId(요청.body)})
        console.log(요청.body)
        응답.status(200).json('삭제완료')
      }
    }
    
    넥스트 버전이 최신꺼라서 오류인건가해서 package.json 에서 "next": "13.2.4" 로 변경해봤는데도 오류가
    그대로입니다. 
    
    
    
    
    
    
    
    
    		
    	
    #79717

    codingapple
    키 마스터
    변경하고 npm install도 해야합니다 
    'use client';
    const ListItem = () => { ... }
    export default ListItem
    으로 바꿔봅시다
    #79889

    양성호
    참가자
    해결된 것 같습니다 감사합니다.
3 글 보임 - 1 에서 3 까지 (총 3 중에서)
  • 답변은 로그인 후 가능합니다.

About

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

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

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