ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • useEffect 2부
    React Hooks 2019. 12. 12. 09:14

    useScrool

    유저가 스크롤해서 뭔가를 지나쳤을때 색상을 바꾸거나 무엇이든지 할 필요가있을때 사용

    import React, { useState, useEffect, useRef } from "react";
    import ReactDOM from "react-dom";
    
    const useScroll = () => {
      const [state, setState] = useState({ x: 0, y: 0 });
      const onScroll = event => {
        setState({ y: window.scrollY, x: window.scrollX });
      };
      useEffect(() => {
        window.addEventListener("scroll", onScroll);
        window.removeEventListener("scroll", onscroll);
      }, []);
      return state;
    };
    
    const App = () => {
      const { y } = useScroll();
      return (
        <div className="App" style={{ height: "1000vh" }}>
          <h1 style={{ position: "fixed", color: y > 100 ? "red" : "blue" }}>Hi</h1>
        </div>
      );
    };
    const rootElement = document.getElementById("root");
    ReactDOM.render(<App />, rootElement);
    

    useFullScreen

    import React, { useState, useEffect, useRef } from "react";
    import ReactDOM from "react-dom";
    
    export const useFullscreen = callback => {
      const element = useRef();
      const runCb = isFull => {
        if (callback && typeof callback === "function") {
          callback(isFull);
        }
      };
      const triggerFull = () => {
        if (element.current) {
          if (element.current.requestFullscreen) {
            element.current.requestFullscreen();
          } else if (element.current.mozRequestFullScreen) {
            element.current.mozRequestFullScreen();
          } else if (element.current.webkitRequestFullscreen) {
            element.current.webkitRequestFullscreen();
          } else if (element.current.msRequestFullscreen) {
            element.current.msRequestFullscreen();
          }
          runCb(true);
        }
      };
      const exitFull = () => {
        document.exitFullscreen();
        if (document.exitFullscreen) {
          document.exitFullscreen();
        } else if (document.mozCancelFullScreen) {
          document.mozCancelFullScreen();
        } else if (document.webkitExitFullscreen) {
          document.webkitExitFullscreen();
        } else if (document.msExitFullscreen) {
          document.msExitFullscreen();
        }
        runCb(false);
      };
      return { element, triggerFull, exitFull };
    };
    
    const App = () => {
      const { element, triggerFull, exitFull } = useFullscreen();
      return (
        <div className="App">
          <div ref={element}>
            <img src="" />
            <button onClick={exitFull}>Exit FullScreen</button>
          </div>
          <button onClick={triggerFull}>Make FullScreen</button>
        </div>
      );
    };
    const rootElement = document.getElementById("root");
    ReactDOM.render(<App />, rootElement);
    

     

     

    'React Hooks' 카테고리의 다른 글

    useEffect  (0) 2019.12.12
    useState  (0) 2019.12.10

    댓글

Designed by Tistory.