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

home2 게시판 React 게시판 useEffect + ajax요청 오류

useEffect + ajax요청 오류

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

    function App() {

    let [수량, 수량변경]= useState(["안녕","하세요","저는"]);
    let [차트정보,차트정보변경] = useState([]);

    useEffect(()=>{

    axios.get("https://btl831.github.io/example1.json")
    .then((result)=>{console.log(result.data); 차트정보변경(result.data)})
    .catch();

    },[]); 해서 

     

    개발자도구로 보면 console 에 로그로 잘 넘오는데 해당 js 에서 {차트정보[0].singer} 처럼 차트정보를 변수로 사용하려는 순간 랜더가 되지않고 오류가 뜹니다. 어떻게 된것일까요....? 그래서 props사용도 불가합니다... 정보가 잘 오는거 같긴한데...

    #15015

    codingapple
    키 마스터

    컴포넌트가 로드될 때

    차트정보라는 state에는 아직 아무것도 안들어있어서 차트정보[0].singer 하면 에러가 나는 것입니다

    ajax 요청은 컴포넌트 로드되고 한참 있다 완료되니까요 

    차트정보.length가 0이 아니면 보여달라는 조건문을 쓰거나 map 반복문을 써봅시다 

    #15016

    그럼 선생님 말대로했을경우 차트정보가 0이면 로딩창을 보여주고 1개라도 생기면 그때 페이지를띄울려고하면 삼항 연산자로 모든 앱을 묶으면 될까요...? 

    #15017

    아니면 useEffect 에서 처리를해야할까요.. 앞에 말한것처럼 모든걸 삼항연산자로 묶어야할까요..? ajax 요청이 완료될때까지 페이지를 띄우지않으려고 합니다!

    #15021

    codingapple
    키 마스터

    로딩중 표시는 html 부분 안에 조건문으로 적으면 됩니다

    모든걸 다 묶으면 사이트가 뭔가 느려보이니까 상품목록 부분만 if문으로 묶도록 합시다 

    #15071

    감사합니다

6 글 보임 - 1 에서 6 까지 (총 6 중에서)
  • 답변은 로그인 후 가능합니다.

About

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

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

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