ホームページ > ウェブフロントエンド > CSSチュートリアル > CSS のみを使用してマルチレベルのドロップダウン メニューを作成するにはどうすればよいですか?

CSS のみを使用してマルチレベルのドロップダウン メニューを作成するにはどうすればよいですか?

Barbara Streisand
リリース: 2024-12-09 06:03:15
オリジナル
396 人が閲覧しました

How to Create Multi-Level Dropdown Menus Using Only CSS?

純粋な CSS を使用したマルチレベルのドロップダウン メニューの作成

純粋な CSS を使用してマルチレベルのドロップダウン メニューを実現することは、あなたが言及した早期の解決策。ここでは、洗練された保守可能な実装を提供する最新のアプローチを示します。

このメソッドは、ネストされた順序なしリスト (

    ) と絶対位置の組み合わせを利用して、マルチレベル構造を作成します。メニューの各レベルは、個別の
      で表されます。

      次のコード スニペットは、メニューの CSS スタイルを提供します。

.third-level-menu {
    position: absolute;
    top: 0;
    right: -150px;
    width: 150px;
    list-style: none;
    padding: 0;
    margin: 0;
    display: none;
}

.third-level-menu > li {
    height: 30px;
    background: #999999;
}
.third-level-menu > li:hover { background: #CCCCCC; }

.second-level-menu {
    position: absolute;
    top: 30px;
    left: 0;
    width: 150px;
    list-style: none;
    padding: 0;
    margin: 0;
    display: none;
}

.second-level-menu > li {
    position: relative;
    height: 30px;
    background: #999999;
}
.second-level-menu > li:hover { background: #CCCCCC; }

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

.top-level-menu > li {
    position: relative;
    float: left;
    height: 30px;
    width: 150px;
    background: #999999;
}
.top-level-menu > li:hover { background: #CCCCCC; }

.top-level-menu li:hover > ul {
    /* On hover, display the next level's menu */
    display: inline;
}

.top-level-menu a /* Apply to all links inside the multi-level menu */ {
    font: bold 14px Arial, Helvetica, sans-serif;
    color: #FFFFFF;
    text-decoration: none;
    padding: 0 0 0 10px;

    /* Make the link cover the entire list item-container */
    display: block;
    line-height: 30px;
}
.top-level-menu a:hover { color: #000000; }
ログイン後にコピー

メニューの HTML 構造は次のとおりです。 :

<ul class="top-level-menu">
    <li><a href="#">About</a></li>
    <li><a href="#">Services</a></li>
    <li>
        <a href="#">Offices</a>
        <ul class="second-level-menu">
            <li><a href="#">Chicago</a></li>
            <li><a href="#">Los Angeles</a></li>
            <li>
                <a href="#">New York</a>
                <ul class="third-level-menu">
                    <li><a href="#">Information</a></li>
                    <li><a href="#">Book a Meeting</a></li>
                    <li><a href="#">Testimonials</a></li>
                    <li><a href="#">Jobs</a></li>
                </ul>
            </li>
            <li><a href="#">Seattle</a></li>
        </ul>
    </li>
    <li><a href="#">Contact</a></li>
</ul>
ログイン後にコピー

このアプローチにより、メニューの応答性が維持され、さまざまな画面サイズやデバイスの向きに適応することが保証されます。また、JavaScript が不要になるため、すべてのブラウザーと互換性があります。

以上がCSS のみを使用してマルチレベルのドロップダウン メニューを作成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート