백엔드에서 데이터 가져오기 질문드립니다.
745
작성한 질문수 13
상세데이터를 가져오기 위해 백엔드를 아래와같이 작성하고
app.get('/api/product/products_by_id', (req, res) => {
//let type = req.query.type
let productId = req.query._id
Product.find({ _id: productId })
.exec((err, product) => {
if(err) return res.status(400).send(err)
return res.status(200).send({success:true, product})
})
})
디테일 페이지는 이렇게 썼는데요.
import React, {useEffect, useState} from 'react';
import axios from 'axios';
function DetailProductPage(props) {
const productId = props.match.params.productId
const [Product, setProduct] = useState([]);
useEffect(() => {
axios.get(`/api/product/products_by_id?id=${productId}&type=single`)
.then(response => {
if(response.data.success){
console.log(response.data)
//setProduct(response.data.proudct[0])
} else {
alert('상세 정보 가져오기 실패했습니다.')
}
})
}, [])
콘솔을 확인해보니
productId도 잘 받아오고
response.data도 success:true는 뜹니다.
하지만 product는 Array(0)으로 나오면서 데이터를 불러오질 못하네요.
서버연결은 되는데 데이터를 못불러오는데 이럴 경우 어디를 수정해야할까요?
답변 1
2
안녕하세요 ethian 님
return res.status(200).send({success:true, product})
여기서 send를 json으로 바꿔주세요 ~!! 수고하세요 ~!
강의 내용은 훌륭하나, 환경 설정 오류 때문에 진도를 나갈 수 없습니다. 20년 버전 강의.
0
60
1
강의자료는 어디서 볼 수있나요??
0
66
1
이 쇼핑몰 만들기 강의는 관리자페이지 만드는건 없나요
0
113
2
웹에서 실시간 코드반영이 안돼요
0
120
1
app.use질문
0
64
1
강사님께 어떻게 직접질문할수있어요??
0
75
1
const함수같은거 기초강의는 어디있나요
0
81
2
리덕스 참조챕터가 어딨어요? 미리듣고오라는데요
0
81
2
강의가완전 오래되서 다 틀리네 app.jsx도 tailwind css 다틀림 무책임함
0
68
1
개발자도구에 redux란이 없어요
0
88
1
npx tailwindcss init -p 에서 계속 에러나요
0
92
1
쇼핑몰기능중 찜하기 기능은 어떻게 구현하나요
0
138
2
강의하다 줌으로 설명가능한지좀 정확히 알려주세요. 이 선생님 정책이 어떻게 되는데요. 직접 연락할 메일이라도 알려주세요
0
43
1
도표 강의 자료 열람 불가능
0
109
1
tailwindcss를 vite에서 이용하는 방식이 바뀐것 같습니다.
0
1130
2
eslint 설정 후 오류가 납니다.
0
221
1
오버로드 오류
0
149
1
VSCode에서 save를 할 때, landingpage의 useEffect가 실행되는 문제에 대하여
0
169
1
dispatch(logoutUser()) 실행시 dispatch(authuser())도 함께 실행되는 문제
0
228
2
logout할 때, server로 요청을 보내서 authUser middleware를 통과하도록 하는 이유?
0
195
1
webkit-text-size-adjust 오류
0
314
1
does not provide an export named 'userReducer'
0
216
2
빌드 배포
0
140
1
삭제 예정 강의는 언제 삭제 되나요? 저것때문에 수강완료를 못하면 회사에서 비용을 청구한다고 합니다~
0
220
2





