ホームページ > ウェブフロントエンド > CSSチュートリアル > 外側の Div のサイズが変更されたときに、スクロール可能な Div が一番下に留まるようにするにはどうすればよいですか?

外側の Div のサイズが変更されたときに、スクロール可能な Div が一番下に留まるようにするにはどうすればよいですか?

Barbara Streisand
リリース: 2024-12-07 20:36:16
オリジナル
453 人が閲覧しました

How Can I Keep a Scrollable Div Stuck to the Bottom When Its Outer Div Resizes?

外側の Div のサイズ変更時にスクロール可能な Div が一番下にくっつく

この記事では、流動的にサイズ変更される外側の Div 内のスクロール動作に関する問題について説明します。目標は、外側の div で高さが変更されても、内側の div である .messages-container の下部近くのスクロール位置を維持することです。

この問題は、.text-input フィールドが動的に拡張されるときに発生します。ユーザーが会話の下部のメッセージを見失ってしまう可能性があります。

CSS を使用した解決策 (flex-direction: column-reverse)

推奨される解決策は、.messages-container div の CSS の flex-direction: column-reverse プロパティを利用します。このアプローチでは、メッセージをコンテナの下部に配置し、一般的なチャット アプリケーションで観察される動作を模倣します。さらに、メッセージが存在しない場合でもスクロールバーが表示されたままになります。

.chat-window {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.chat-messages {
  flex: 1;
  height: 100%;
  overflow: auto;
  display: flex;
  flex-direction: column-reverse;
}
ログイン後にコピー

注意点とブラウザの互換性

ただし、この方法では IE でバグが発生する可能性があります。 /Edge/Firefox でスクロールバーが非表示になります。

の回避策IE/Edge/Firefox

この問題に対処するには、flex-direction: columns-reverse の動作を模倣する回避策を採用できます。

// scroll to bottom
function updateScroll(el) {
  el.scrollTop = el.scrollHeight;
}

// only shift-up if at bottom
function scrollAtBottom(el) {
  return (el.scrollTop + 5 >= (el.scrollHeight - el.offsetHeight));
}
ログイン後にコピー

これらの関数を組み込むことで、コードに組み込むと、IE/Edge/Firefox が flex-direction と同じスクロール動作を示すようになります。列反転。

// ...

if (atbottom && (!isWebkit || isEdge)) {
  updateScroll(msgdiv);
}
ログイン後にコピー

以上が外側の Div のサイズが変更されたときに、スクロール可能な Div が一番下に留まるようにするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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