<"/> <">

ホームページ >ウェブフロントエンド >フロントエンドQ&A >jqueryで左メニューバーの左右縮小を実現

jqueryで左メニューバーの左右縮小を実現

王林
王林オリジナル
2023-05-28 10:06:07900ブラウズ

Web サイトの機能がますます複雑になるにつれて、左側のメニュー バーがほぼすべての Web ページの標準機能になりました。ただし、デザイナーの中には、メニュー バーが Web ページ上で多くのスペースを占め、Web ページの美しさが損なわれると考える人もいるかもしれません。この問題を解決するには、jQueryを使用してメニューバーの左右縮小機能を実現します。

この記事では、jQuery を使用して、左側のメニュー バーの左右の縮小効果を実現する方法を紹介します。

  1. HTML 構造

まず、基本的な HTML 構造を構築する必要があります。コードは次のとおりです。

<div class="menu">
  <div class="menu-toggle">
    <i class="fa fa-bars"></i>
  </div>
  <ul class="menu-list">
    <li><a href="#">Menu 1</a></li>
    <li><a href="#">Menu 2</a></li>
    <li><a href="#">Menu 3</a></li>
  </ul>
</div>

ここでは、「menu」という名前の div コンテナを作成します。このコンテナには、「menu-toggle」と「menu-list」という 2 つのサブ要素が含まれています。

  1. CSS スタイル

次に、メニュー バーに CSS スタイルを追加する必要があります。コードは次のとおりです。

.menu {
  width: 250px;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  background-color: #333;
  color: #fff;
  overflow-x: hidden;
}

.menu-toggle {
  width: 50px;
  height: 50px;
  line-height: 50px;
  font-size: 24px;
  text-align: center;
  cursor: pointer;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #555;
  color: #fff;
  z-index: 999;
}

.menu-list {
  margin-top: 50px;
  padding: 0;
  list-style: none;
}

.menu-list li {
  padding: 10px;
}

.menu-list li a {
  color: #fff;
  text-decoration: none;
}

/* 隐藏滚动条 */
::-webkit-scrollbar {
  display: none;
}

この CSS スタイルでは、メニュー バーの幅と高さ、および絶対的な配置位置を設定します。次に、メニュー バーのトグル ボタン、メニュー バー リストなど、メニュー バーのサブ要素にスタイルを追加します。

  1. JS コード

次に、jQuery を使用してメニュー バーの左右の縮小効果を追加する必要があります。コードは次のとおりです。

$(document).ready(function() {
  // 默认情况下,菜单栏打开
  var menuState = "open";

  // 点击按钮时切换菜单栏状态
  $(".menu-toggle").click(function() {
    if (menuState == "open") {
      $(".menu").animate({left: "-250px"}, 300);
      menuState = "closed";
    } else {
      $(".menu").animate({left: "0px"}, 300);
      menuState = "open";
    }
  });
});

この JS コードでは、メニュー バーのステータスを追跡する変数「menuState」を定義します。メニューバーの切り替えボタンをクリックするたびにメニューバーの状態が判別され、状態に応じてメニューバーが切り替わります。

  1. 完全な例

これで、左側のメニュー バーの単純な左右の縮小効果が完成しました。上記の HTML、CSS、JS コードを組み合わせて完全な例を作成します。

<!doctype html>
<html>
<head>
  <meta charset="UTF-8">
  <title>jQuery实现左侧菜单栏左右收缩</title>
  <link rel="stylesheet" href="https://cdn.bootcss.com/font-awesome/4.7.0/css/font-awesome.min.css">
  <style>
    .menu {
      width: 250px;
      height: 100%;
      position: fixed;
      top: 0;
      left: 0;
      background-color: #333;
      color: #fff;
      overflow-x: hidden;
    }
    .menu-toggle {
      width: 50px;
      height: 50px;
      line-height: 50px;
      font-size: 24px;
      text-align: center;
      cursor: pointer;
      position: absolute;
      top: 0;
      left: 0;
      background-color: #555;
      color: #fff;
      z-index: 999;
    }
    .menu-list {
      margin-top: 50px;
      padding: 0;
      list-style: none;
    }
    .menu-list li {
      padding: 10px;
    }
    .menu-list li a {
      color: #fff;
      text-decoration: none;
    }
    /*隐藏滚动条*/
    ::-webkit-scrollbar {
      display: none;
    }
  </style>
</head>
<body>
  <div class="menu">
    <div class="menu-toggle">
      <i class="fa fa-bars"></i>
    </div>
    <ul class="menu-list">
      <li><a href="#">Menu 1</a></li>
      <li><a href="#">Menu 2</a></li>
      <li><a href="#">Menu 3</a></li>
    </ul>
  </div>

  <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
  <script>
    $(document).ready(function() {
      // 默认情况下,菜单栏打开
      var menuState = "open";

      // 点击按钮时切换菜单栏状态
      $(".menu-toggle").click(function() {
        if (menuState == "open") {
          $(".menu").animate({left: "-250px"}, 300);
          menuState = "closed";
        } else {
          $(".menu").animate({left: "0px"}, 300);
          menuState = "open";
        }
      });
    });
  </script>
</body>
</html>
  1. 概要

上記は、左側のメニュー バーの左右の縮小効果を実現するための完全な手順です。 jQuery を使用すると、この機能を簡単に追加し、Web ページの美しさを向上させることができます。この記事がお役に立てば幸いです。

以上がjqueryで左メニューバーの左右縮小を実現の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。