ホームページ >ウェブフロントエンド >CSSチュートリアル >ネストされたスティッキー位置決めが失敗するのはなぜですか? どうすれば修正できますか?

ネストされたスティッキー位置決めが失敗するのはなぜですか? どうすれば修正できますか?

Patricia Arquette
Patricia Arquetteオリジナル
2024-12-21 04:07:10723ブラウズ

Why Does Nested Sticky Positioning Fail, and How Can I Fix It?

スティッキー配置のジレンマ: ネストすると失敗する理由

position: Sticky を指定して要素を別の要素内に配置すると、動作しなくなる可能性があります予想通り。これは、スティッキー配置では親要素のサイズが考慮されるためです。

問題の理解

提供された例では、

.nav-wrapper {
  position: absolute;
  bottom: 0;
}

親要素(nav-wrapper) は、ナビゲーションの高さに基づいて高さを定義します。 element.

<div class="nav-wrapper">
  <nav>
    <a href="#">...</a>
    <a href="#">...</a>
  </nav>
</div>

nav の位置が Sticky の場合、ブラウザ ウィンドウの上部に固定されることが期待されます。ただし、親要素が利用可能な垂直方向のスペースをすべて占有しているため、ナビゲーションを固定する余地はありません。

問題の解決

固定機能を作成するにはこのシナリオでは、親とは独立して nav 要素に独自の高さを与えることができます。

.nav-wrapper {
  position: absolute;
  bottom: 0;
  height: 50px;
}

.nav-wrapper nav {
  position: sticky;
  top: 0;
  height: 100%;
}

両方の高さを設定することで、 nav-wrapper と nav を使用すると、スティッキー配置が正しく機能するために十分な垂直スペースが作成されます。

以上がネストされたスティッキー位置決めが失敗するのはなぜですか? どうすれば修正できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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