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

home2 게시판 React 게시판 setInterval관련 질문

setInterval관련 질문

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

    주상후
    참가자
    setInterval을 통해 캐러셀을 계속 움직이게 하려니까 오류가 생기더라구요
    그래서 구글링해서 useInterval함수를 만들어서 사용하라고 해서 코드를 고쳤습니다.
    
    useInterval함수는 
    
    function useInterval(callback, delay) {
      const savedCallback = useRef(null);
      useEffect(() => {
        savedCallback.current = callback;
      }, [callback]);
      useEffect(() => {
        const executeCallback = () => {
          savedCallback.current();
        };
        const timerId = setInterval(executeCallback, delay);
        return () => clearInterval(timerId);
      }, []);
    };
    이렇게 만들었고
    useEffect(()=>{
        useInterval(()=> {
          if(mainCarouselImgNum != 3)
                setMainCarouselImgNum(mainCarouselImgNum+1);
            else
              setMainCarouselImgNum(1);
        },4000);
      },[])
    처음 들어왔을 때만 실행되도록 useEffect를 사용했습니다. 그런데 오류메세지로 useInterval에 콜백함수를 넣으라고 오류 메세지가 계속 생깁니다.
    useEffect없이 useInterval만 적으면 작동이 매우 잘 되는데 useEffect에 넣으면 작동이 되지 않습니다.
    어떻게 해야 하나요?
    
    
    
    
    #48155

    codingapple
    키 마스터
    useInterval(()=> { 를 useEffect안에 안담아도 알아서 잘될듯요 
    useInterval 안에 1회실행되는 useEffect가 잘 있군요
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 호 / 개인정보관리자 : 박종흠