zoukankan      html  css  js  c++  java
  • react实现自定义hooks(跑马灯)

    实现思路

    transform+transition,setTimeout+递归实现偏移滚动

    在线预览

    react跑马灯hooks

    核心代码

    import { useState, useRef, useCallback } from "react";
    
    function useMarquee({ data, listRef, wrapRef }) {
      const [transform, setTransform] = useState("none");
      const [transition, setTransition] = useState("none");
      const durationRef = useRef();
      const delayRef = useRef();
      const countRef = useRef(0);
    
      const move = useCallback(
        (duration) => {
          let height = 0;
          const element = listRef.current?.children[0];
          height = element.offsetHeight;
          setTransform(`translateY(-${height}px)`);
          setTransition(`transform ${duration / 1000}s linear`);
        },
        [listRef]
      );
      const reset = useCallback(() => {
        countRef.current += 1;
        setTransform("none");
        setTransition("none");
      }, []);
      const start = useCallback(
        ({ delay, duration }) => {
          if (!listRef.current?.children[0] || data.length < 4) {
            return;
          }
          const viewHeight = wrapRef.current?.offsetHeight;
          const element = listRef.current?.children[0];
          const itemHeight = element.offsetHeight;
          const num = Math.floor(Number(viewHeight) / itemHeight) + 1;
          if (countRef.current >= data.length - num) {
            // return;
            countRef.current = 0;
          }
          window.clearTimeout(delayRef.current);
          delayRef.current = window.setTimeout(() => {
            move(duration);
            window.clearTimeout(durationRef.current);
            durationRef.current = window.setTimeout(reset, duration);
            start({ delay, duration });
          }, delay);
        },
        [data.length, listRef, wrapRef, move, reset]
      );
      return { start, index: countRef.current, transform, transition };
    }
    
    export default useMarquee;
    
    
  • 相关阅读:
    Python多线程笔记(三),queue模块
    Python多线程笔记(二)
    Python多线程笔记(一)
    Python3对时间模块的操作
    解决 ImportError: No module named 'pip._internal'问题
    Python字符串的操作
    Python 的AES加密与解密
    第十一周学习进度报告
    各组建议
    用户场景分析
  • 原文地址:https://www.cnblogs.com/xingguozhiming/p/15787394.html
Copyright © 2011-2022 走看看