當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript react.useLayoutEffect函數代碼示例

本文整理匯總了TypeScript中react.useLayoutEffect函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript useLayoutEffect函數的具體用法?TypeScript useLayoutEffect怎麽用?TypeScript useLayoutEffect使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了useLayoutEffect函數的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: useComponentSize

export function useComponentSize(ref: React.RefObject<HTMLElement>) {
  let [componentSize, setComponentSize] = useState(getSize(ref.current));

  const handleResize = useCallback(
    function handleResize() {
      if (ref.current) {
        setComponentSize(getSize(ref.current));
      }
    },
    [ref]
  );

  useLayoutEffect(() => {
    if (!ref.current) {
      return;
    }

    if (SUPPORTS_RESIZE_OBSERVER) {
      let resizeObserver = new ResizeObserver(() => handleResize());
      resizeObserver.observe(ref.current);

      return () => {
        resizeObserver.disconnect();
      };
    } else {
      window.addEventListener('resize', handleResize);

      return () => {
        window.removeEventListener('resize', handleResize);
      };
    }
  }, [handleResize, ref]);

  return componentSize;
}
開發者ID:LWJGL,項目名稱:lwjgl3-www,代碼行數:35,代碼來源:useComponentSize.ts

示例2: useUnmount

export function useUnmount() {
  const unmounted = useRef(true)

  useLayoutEffect(() => {
    unmounted.current = false
    return () => {
      unmounted.current = true
    }
  }, [])

  return unmounted
}
開發者ID:8th713,項目名稱:cockpit-for-pixiv,代碼行數:12,代碼來源:useUnmount.ts

示例3: useOnScreen

export function useOnScreen(ref: React.RefObject<Element>, options?: IntersectionObserverInit) {
  const [isIntersecting, setIntersecting] = useState(false);

  useLayoutEffect(() => {
    if (ref.current) {
      const observer = new IntersectionObserver(([entry]) => setIntersecting(entry.isIntersecting), options);
      observer.observe(ref.current);
      return () => {
        observer.disconnect();
      };
    }
  }, [ref, options]);

  return isIntersecting;
}
開發者ID:LWJGL,項目名稱:lwjgl3-www,代碼行數:15,代碼來源:useOnScreen.ts

示例4: useResizeObserver

export function useResizeObserver(target: React.RefObject<HTMLElement>) {
  const [rect, setRect] = useState(getZeroRect);
  const observer: React.MutableRefObject<ResizeObserver | null> = useRef(null);

  useLayoutEffect(() => {
    function handleResize(entries: Array<ResizeObserverEntry>) {
      setRect(entries[0].contentRect);
    }

    observer.current = new ResizeObserver(handleResize);
    if (target.current !== null) {
      observer.current.observe(target.current);
    }

    return () => {
      if (observer.current !== null) {
        observer.current.disconnect();
        observer.current = null;
      }
    };
  }, []);

  return rect;
}
開發者ID:LWJGL,項目名稱:lwjgl3-www,代碼行數:24,代碼來源:useResizeObserver.ts

示例5: usePlayer

export function usePlayer(
  ref: React.RefObject<HTMLCanvasElement>,
  frames: Frame[]
) {
  const timerRef = useRef(0)
  const [index, setIndex] = useState(0)
  const [paused, setPaused] = useState(false)

  function draw(image: HTMLImageElement) {
    if (!image || !ref.current) return

    const canvas = ref.current

    if (canvas.width !== image.width) {
      canvas.width = image.width
    }
    if (canvas.height !== image.height) {
      canvas.height = image.height
    }

    const ctx = canvas.getContext('2d')!

    ctx.clearRect(0, 0, canvas.width, canvas.height)
    ctx.drawImage(image, 0, 0)
  }
  function next() {
    const lastFrame = frames.length - 1

    if (index === lastFrame) {
      setIndex(0)
    } else {
      setIndex(index + 1)
    }
  }
  function toggle() {
    if (paused) {
      setPaused(false)
      next()
    } else {
      window.clearTimeout(timerRef.current)
      setPaused(true)
    }
  }
  function rewind() {
    window.clearTimeout(timerRef.current)
    setPaused(true)
    setIndex(0)
  }

  useLayoutEffect(() => {
    const { delay, image } = frames[index]

    draw(image)

    if (!paused) {
      timerRef.current = window.setTimeout(next, delay)
    }
    return () => {
      window.clearTimeout(timerRef.current)
    }
  }, [index])

  return { index, paused, toggle, rewind }
}
開發者ID:8th713,項目名稱:cockpit-for-pixiv,代碼行數:64,代碼來源:usePlayer.ts


注:本文中的react.useLayoutEffect函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。