캐러셀 동작원리
안녕하세요 재남님 강의 너무 잘듣고 있습니다
제가 지금 캐러셀 공부하면서 궁금한것이
캐러셀 각 이미지에 ref를 다 할당한다
슬라이드 이벤트 화살표 클릭시 이동할 인덱스를 계산하고 인덱스를 기준으로 current와 next의 ref를 가져온다
그럼 가져온 ref에 각각 애니메이션 클래스네임을 할당한다 애니메이션에 따라 translateX만큼 이동 , 마지막으로 이동한 인덱스 상태변화
이렇게 동작원리를 이해를 하였습니다 그래서 일단 animationend는 없어도 될거 같아서 일단 없애고 코드를 작성하니 화면 전환은 되는데 자연스러운 슬라이드가 아니라 그냥 뚝뚝끊기는 이미지 전환이 되고있습니다.. 제 생각엔 handleAnimationEnd함수는 애니메이션 동작완료후 동작하는것이라고 알고있는데 애니메이션이 동작을 안하는 이유를 모르겠습니다
const moveTo = useCallback(
(nextIndex: number, direction?: Direction) => {
const $current = itemsRef.current![currentIndex] as HTMLLIElement;
const $next = itemsRef.current![nextIndex] as HTMLLIElement;
if (nextIndex === currentIndex) return;
const dir = direction || (nextIndex > currentIndex ? "right" : "left");
// const handleAnimationEnd = () => {
// $current.className = cx("item");
// $next.className = cx("item", "current");
// $current.removeEventListener("animationend", handleAnimationEnd);
// setCurrentIndex(nextIndex);
// };
// $current.addEventListener("animationend", handleAnimationEnd);
$current.classList.add(cx(`${dir}_current`));
$next.classList.add(cx(`${dir}_next`));
setCurrentIndex(nextIndex);
},
[currentIndex]
);
답변 2
미션6 진행 관련 , /config -> output style 선택항목에 보이지 않는데...
0
5
2
요구사항인터뷰 강의자료 안보임
0
4
2
4강 강의 교안 소스코드
0
4
0
한글 밀림현상
0
9
1
cursor 단축키 관련 문의
0
8
1
커리큘럼 비활성화
0
9
2
12.13) 하단 여백 스타일링 관련 질문 드립니다.
0
10
1
Supabase 프로젝트 Claude 초기화 질문
0
12
2
27강 Context내 RSC 사용 관련 문의
0
17
2
화면 안 나옴
0
16
1
설명하시는 개념들을 잘 모르겠습니다.
0
14
2
안티그래비티 업데이트
0
33
2
제네릭을 사용하실 때 콤마
0
170
2
popover createPortal 방식에서
0
154
2
스낵바를 만들 때 snackBarContext와 snackBarSetContext
0
150
2
snackbar를 createportal를 썻을 때 갯수 조절이 가능한가요?
0
197
1
useCallback, useMemo의 차이에 대해서 궁금합니다.
0
371
1
createPortal 활용해서 modal 만들 때 활용한 MutationObserver 코드 관련 질문
0
359
3
강의자료 (보일러플레이트) 다운로드 관련 질문
0
257
1
모달만드는 방식 질문
0
245
1
dropdown 내부에서 data의 타입을 알아야 할까요?
0
201
1
Provider를 외부에 노출하는 것보다 내부 로직으로 숨기는 것은 어떤가요?
0
290
2
keyEventMap를 전역에 구현하신 이유가 궁금합니다!
0
274
2
테일윈드로 포탈로 모달작성시 뒤에 클릭이 안됩니다
1
317
2





