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

home2 게시판 React 게시판 리액트에서 서버와 통신하려면 ajax 2 : post, fetch - 응용 1,2,3

리액트에서 서버와 통신하려면 ajax 2 : post, fetch - 응용 1,2,3

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

    최문길
    참가자
    function App() {
    
    
     // 1,2,3번 state임
      let [isLoading,setLoading] = useState(false); // 3번 응용 로딩 끝나거나 못받아오면..
      let [count,setCount] = useState(0); 
      let [btn,setBtn] = useState(true);  // 7,8,9번 상품 데이터 가져오면 없애기 state임
      // 1,2,3번 관련 함수임 
      const ajaxFunc = (url)=>{
        axios.get(url[count])
        .then((result)=>{
          let newProduct = [...shoes,...result.data];
          setShoes(newProduct)
     
          url.length == count ? setBtn(false) : setBtn(true) // 7,8,9번째 상품 보여주면 state 변경으로 바꿔주기
          setLoading(false)// <- 이렇게 하는거 맞나요?
        })
        .catch(()=>{
          setLoading(false)  <- 이렇게 하는거 맞나요?
          console.log('못받아왔어용')
        })
        setCount(count = count + 1)// setCount를 아래로 둔 이유는 버튼 클릭하면 함수가 실행이 됨,
     실행 하면서 동기적 처리 후 에 count 변화 주려고 (array자료는 0부터 시작이잖슴)
      }
    
    return(
      
     {isLoading == true ? <div className='text-success bg-dark'>로딩중</div> :null }
    
     {           
                btn == true ?<button className='btn btn-warning mx-3'onClick={()=>{
                  // 3번째 응용 state임
                  setLoading(true)
      
                  // url 배열임
                  let ajaxArr = [
                    'https://codingapple1.github.io/shop/data2.json',
                    'https://codingapple1.github.io/shop/data3.json'
                  ]
                  ajaxFunc(ajaxArr) // 1번,2번,3번 다 있는 함수 임
      
      
                }}>버튼</button> : null
    )
    ---------------
    get 후 
    then에 isLoading(false) 
    못 받아오면 
    cath에 isLoading(false)
    이게 쌤이 말한 것과 맞는 건지 헷갈리네요
    
    ---------------------------
    쌤 코드 리뷰해주세요 url 배열을 안에다 넣는거 별로일꺼 같은
     느낌적인 직감은 있는데 저 스스로 만족하기가 90%도 안되네요
    
    
    
    
    #97635

    codingapple
    키 마스터
    setLoading은 잘한듯요 
    setCount(count = count + 1) 함수소괄호안에 보통 등호를 쓰진 않습니다 
    url보관 싫으면 url안의 숫자만 변경해서 써도 될듯요
2 글 보임 - 1 에서 2 까지 (총 2 중에서)
  • 답변은 로그인 후 가능합니다.

About

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

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

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