目次
以下の説明を容易にするために、まず HTML を次のように統合します。
1. height
1.1 絶対配置と負のマージン:
1.2 絶対位置決めと margin:auto:
1.3 Clear float:
2. 子要素の高さが適応される場合
2.1 div の表示モードはテーブルに設定されます:
2.2 css3 変換のtranslate属性:
2.3 フレックスボックス
ホームページ ウェブフロントエンド htmlチュートリアル CSS div 垂直 centering_html/css_WEB-ITnose のまとめ

CSS div 垂直 centering_html/css_WEB-ITnose のまとめ

Jun 21, 2016 am 08:59 AM

コードを書くときに、垂直方向のセンタリングの問題によく遭遇します。私は通常、絶対位置と負のマージンを使用してセンタリングを実現します。ただし、実際のプロジェクトでは、上記の方法があまり信頼できない特殊な状況が発生することがよくあります。したがって、より効果的な方法が特に重要です。

説明部分

この記事ではブラウザの互換性の問題については考慮していません。参考としていくつかの方法を提供するだけです。実際の開発時に実際の状況に応じて選択してください。特に現在人気のレスポンシブページでは、高さが固定されていないエフェクトの使用に適していない場合があります。容量には限りがあります。後でさらに方法を追加する場合は、お問い合わせください。

テキストの始まり

以下の説明を容易にするために、まず HTML を次のように統合します。

<div id="parent">    <div id="child">子div居中</div></div>
ログイン後にコピー

1. height

1.1 絶対配置と負のマージン:

このメソッドは絶対配置の div を使用し、その上部を 50% に設定し、margin-top を div の高さの負の半分に設定します。

#parent {    position: relative;    width: 600px;    height: 600px;    background-color: #ccc;}#child {    position: absolute;    top: 50%;    left: 50%;    height: 30%;    width: 50%;    margin: -15% 0 0 -25%;    background-color: #fff;}    
ログイン後にコピー

1.2 絶対位置決めと margin:auto:

このメソッドは、幅と高さが固定されたposition:absolute divを使用します。この div は、上:0、下:0 に設定されます。ただし、高さが固定されているため、実際には上下の間隔を 0 にすることはできず、margin:auto によって中央に配置されます。

#parent {    position: relative;    width: 600px;    height: 600px;    background-color:#ccc;}#child{    position: absolute;    top: 0;    bottom: 0;    left: 0;    right: 0;    margin: auto;    width:100px;    height:100px;    background-color: #fff;}
ログイン後にコピー

1.3 Clear float:

このメソッドでは、子 div の外側に div が挿入されます。この div height:50% を子 div の高さに設定します。子 div は float から削除され、中央に表示されます。

上記の HTML を次のように変更します。

<div id="parent">    <div id="floater"></div>      <div id="child">子div居中</div></div>
ログイン後にコピー

css を次のように変更します。

#parent{     width: 600px;     height: 600px;    background-color: #ccc;}#floater {    float: left;    height: 50%;    margin-bottom: -50px;    background-color: #f00;}#child {    clear: both;    width: 100px;    height: 100px;    margin: 0 auto;    background-color: #fff;}
ログイン後にコピー

2. 子要素の高さが適応される場合

2.1 div の表示モードはテーブルに設定されます:

親 div の表示モードはテーブルに設定されているため、テーブルの垂直方向の配置を使用できます

#parent {    width:600px;     height:600px;    display: table;    background-color:#ccc;}#child {    display: table-cell;    vertical-align: middle;    background-color:#0f0;}
ログイン後にコピー

2.2 css3 変換のtranslate属性:

まず要素をコンテナの中心に配置し、次にtransformのtranslate属性を使用して要素の中心を親コンテナの中心と一致させます。

#parent {      position: relative;    width: 600px;    height:600px;    overflow: hidden;    background-color:#ccc;}#child{    position: absolute;    top: 50%;    background-color: #0f0;    transform: translateY(-50%);}
ログイン後にコピー

transform を使用する 欠点の 1 つは、計算結果に小数が含まれる場合 (0.5 など)、要素全体がぼやけて見えることです。解決策の 1 つは、transform-style:preserve- を設定することです。親要素の 3d; スタイル:

#parent{    -webkit-transform-style: preserve-3d;      -moz-transform-style: preserve-3d;      transform-style: preserve-3d;}#child {      position: relative;      top: 50%;      transform: translateY(-50%);}
ログイン後にコピー

2.3 フレックスボックス

水平方向と垂直方向の中央揃えを実現するには、フレックスボックスを使用します。2 つの中央揃えプロパティを使用するだけです

#parent{     width:600px;    height:600px;    display: flex;    justify-content: center;    align-items: center;    background-color:#eee;}#child {    background-color: #0f0;}
ログイン後にコピー

フロントエンド初心者向けに知識を整理するため、誤りがあれば修正してください

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

&lt; Progress&gt;の目的は何ですか 要素? &lt; Progress&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:34 PM

この記事では、HTML&lt; Progress&gt;について説明します。要素、その目的、スタイリング、および&lt; meter&gt;との違い要素。主な焦点は、&lt; Progress&gt;を使用することです。タスクの完了と&lt; Meter&gt; statiの場合

&lt; datalist&gt;の目的は何ですか 要素? &lt; datalist&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:33 PM

この記事では、HTML&lt; Datalist&GT;について説明します。オートコンプリートの提案を提供し、ユーザーエクスペリエンスの改善、エラーの削減によりフォームを強化する要素。

&lt; meter&gt;の目的は何ですか 要素? &lt; meter&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:35 PM

この記事では、html&lt; meter&gt;について説明します。要素は、範囲内でスカラーまたは分数値を表示するために使用され、Web開発におけるその一般的なアプリケーション。それは差別化&lt; Meter&gt; &lt; Progress&gt;およびex

ビューポートメタタグとは何ですか?レスポンシブデザインにとってなぜそれが重要なのですか? ビューポートメタタグとは何ですか?レスポンシブデザインにとってなぜそれが重要なのですか? Mar 20, 2025 pm 05:56 PM

この記事では、モバイルデバイスのレスポンシブWebデザインに不可欠なViewportメタタグについて説明します。適切な使用により、最適なコンテンツのスケーリングとユーザーの相互作用が保証され、誤用が設計とアクセシビリティの問題につながる可能性があることを説明しています。

HTML5&lt; time&gt;を使用するにはどうすればよいですか 日付と時刻を意味的に表す要素? HTML5&lt; time&gt;を使用するにはどうすればよいですか 日付と時刻を意味的に表す要素? Mar 12, 2025 pm 04:05 PM

この記事では、html5&lt; time&gt;について説明します。セマンティックデート/時刻表現の要素。 人間の読み取り可能なテキストとともに、マシンの読みやすさ(ISO 8601形式)のDateTime属性の重要性を強調し、Accessibilitを増やします

HTML5のクロスブラウザー互換性のベストプラクティスは何ですか? HTML5のクロスブラウザー互換性のベストプラクティスは何ですか? Mar 17, 2025 pm 12:20 PM

記事では、HTML5クロスブラウザーの互換性を確保するためのベストプラクティスについて説明し、機能検出、プログレッシブエンハンスメント、およびテスト方法に焦点を当てています。

HTML5フォーム検証属性を使用してユーザー入力を検証するにはどうすればよいですか? HTML5フォーム検証属性を使用してユーザー入力を検証するにはどうすればよいですか? Mar 17, 2025 pm 12:27 PM

この記事では、ブラウザのユーザー入力を直接検証するために、必要、パターン、MIN、MAX、および長さの制限などのHTML5フォーム検証属性を使用して説明します。

&lt; iframe&gt;の目的は何ですか タグ?使用する際のセキュリティ上の考慮事項は何ですか? &lt; iframe&gt;の目的は何ですか タグ?使用する際のセキュリティ上の考慮事項は何ですか? Mar 20, 2025 pm 06:05 PM

この記事では、&lt; iframe&gt;外部コンテンツをWebページ、その一般的な用途、セキュリティリスク、およびオブジェクトタグやAPIなどの代替案に埋め込む際のタグの目的。

See all articles