0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

React、cssでドロアーのメニュー(MUIやChakraUIは未使用)

Last updated at Posted at 2022-07-02

React、cssでドロアーのメニューを実装したときのメモです。画面外からメニューが出てきます。
MUIやChakraUIなどのライブラリは使用しておりません。
左から出るメニューと右から出るメニューを作成しました。
左から出るメニューに関しては、closeボタン押下でメニューを閉じます。
右から出るメニューに関しては、メニュー外をクリックするとメニューを閉じます。
1.jpg

左から出るメニュー

DrawerMenuLeftのcssを当ててメニューを画面外に表示します。メニューアイコン押下時は.DrawerMenuLeft--isOpenのcssを追加で当てることでメニューが画面内に移動します。

css (必要なもののみ抜粋)
.DrawerMenuLeft {
  transition: all 0.3s ease-in-out;
  transform: translate(-200px);
  position: fixed;
}
.DrawerMenuLeft--isOpen {
  transform: translate(0);
}
ソース (必要なもののみ抜粋)
  const [isOpenLeft, setIsOpenLeft] = useState<boolean>(false);
  const onMenuColseLeft = () => {
    setIsOpenLeft(false);
  };
  const onMenuIconClickRight = () => {
    setIsOpenRight(true);
  };
       
       
  return (
    <>
       
       
      <nav
        className={`DrawerMenuLeft ${isOpenLeft && "DrawerMenuLeft--isOpen"}`}
      >
        <ul>menu-left</ul>
        <button className="CloseButton" onClick={onMenuColseLeft}>
          close
        </button>
      </nav>

右から出るメニュー

DrawerMenuRightのcssを当ててメニューを画面外に表示します。メニュー外クリック時は.DrawerMenuRight--isOpenのcssを追加で当てることでメニューが画面内に移動します。
右側なので、起点はright: 0;としています。また、今回はクリック座標とメニューの座標を比較することで、メニュー外でクリックされたと判断しました。
※メニューの下に全画面表示のラベル等を表示してそこをクリックするとメニューを消す方法もあります

css (必要なもののみ抜粋)
.DrawerMenuRight {
  transition: all 0.3s ease-in-out;
  right: 0;
  transform: translate(200px);
  position: fixed;
}
.DrawerMenuRight--isOpen {
  transform: translate(0);
}
ソース (必要なもののみ抜粋)
  const [isOpenLeft, setIsOpenLeft] = useState<boolean>(false);

  const concernedElement = document.querySelector(".DrawerMenuRight");
  const handleClickOutside = useCallback(
    (e: MouseEvent): void => {
      if (concernedElement && isOpenRight) {
        if (
          e.pageX < concernedElement.getBoundingClientRect().x ||
          e.pageY >
            concernedElement.getBoundingClientRect().y +
              concernedElement.clientHeight
        ) {
          setIsOpenRight(false);
        }
      }
    },
    [isOpenRight, concernedElement]
  );

  const onMenuIconClickRight = () => {
    setIsOpenRight(true);
  };

  useEffect(() => {
    document.addEventListener("click", handleClickOutside, true);
    return () => {
      document.removeEventListener("click", handleClickOutside, true);
    };
  }, [handleClickOutside]);
       
       
  return (
    <>
       
       
      <nav
        className={`DrawerMenuRight ${isOpenRight && "DrawerMenuRight--isOpen"}`}
      >
        <ul>menu-right</ul>
      </nav>

参考

https://medium.com/@albertchu539/how-to-make-an-app-drawer-with-react-hooks-and-css-1338ae57afb4
https://blog.logrocket.com/detect-click-outside-react-component-how-to/

0
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?