ホームページ ウェブフロントエンド htmlチュートリアル CSS_html/css_WEB-ITnose の水平方向と垂直方向の中央揃え

CSS_html/css_WEB-ITnose の水平方向と垂直方向の中央揃え

Jun 24, 2016 am 11:22 AM

CSS の世界では、ブロック レベルの要素を水平方向に中央揃えにしたい場合、誰もが margin:0 auto; の使用方法を知っていなければなりません。そうすれば、ブロック レベルの要素は親要素の中で水平方向に中央揃えに配置されます。

は次のようにリストされます:

<!DOCTYPE html>    <head>        <title>center</title>        <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>        <style>                .parent {                width:50%;                height:100px;                border:1px solid black;                position:relative;            }            .child {                margin:0 auto;                width:50px;                height:50px;                background:#22B14C;            }            </style>    </head>    <body>        <div class="parent">               <div class="child">                         </div>        </div>    </body></html>
ログイン後にコピー

実行効果図は次のとおりです。緑の四角形は親要素の水平方向の中心にあります

、では、問題は、緑の四角形を次のようにしたいかということです。垂直方向または水平方向と垂直方向の中央に配置されますか?

margin:auto 0; または margin:auto; を設定するだけで十分ですか?

margin: 0 auto に設定すると水平方向に中央揃えにできるので、私もそう思っていました。

しかし、垂直方向のセンタリングの場合はそうではありません。

通常のドキュメントフローでは、margin:auto を設定すると、ブラウザが解析するときに margin:0 auto;

(margin-top と margin-bottom を 0 に設定し、margin-left と margin を設定します) -right は左右適応に設定されます)。

W3.orgより抜粋

心配な場合は、上記のデモの margin:0 auto; を margin:auto; に置き換えても、操作後の結果は同じになります。

ねえ、ブロック レベルの要素を垂直方向の中央に配置したい場合はどうすればよいでしょうか?

方法 1:

要素を絶対配置に設定します。これにより、要素を通常のドキュメント フローから分離できます。absolute には、要素の表示をブロックに設定するという機能があります。

次に、絶対配置座標 (左、上、右、下) を 0 に設定します。これにより、ブラウザーは絶対配置用に新しいボックス モデルをラップします。

margin と組み合わせると、水平方向の中央揃え (margin:0 auto;)、垂直方向の中央揃え (margin:auto 0;)、水平方向と垂直方向の中央揃え (margin:auto;) を完璧に行うことができます。

以下のデモは「水平方向と垂直方向のセンタリング」です:

<!DOCTYPE html>    <head>        <title>center</title>        <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>        <style>                .parent {                width:50%;                height:100px;                border:1px solid black;                position:relative;            }            .child {                margin: auto;                position: absolute;                top:0;                left:0;                bottom:0;                right:0;                width:50px;                height:50px;                background:#22B14C;            }            </style>    </head>    <body>        <div class="parent">                   <div class="child">                         </div>        </div>    </body></html>
ログイン後にコピー

PS: position:fixed もドキュメント フローから分離できるため、absolute と同じですが、違いは次のとおりです。固定されたものは、ブラウザ ウィンドウの位置に相対的です。

方法 2:

方法 1 は要素のドキュメント フローを変更することですが、そのドキュメント フローを変更する場合はどうでしょうか?

次に、別の方法を見つけて、要素の幅と高さを計算しましょう。

どういう意味ですか?

「垂直方向の中央揃え」を例に挙げます。子要素がある場合、その親要素であるparentを中心に垂直方向の中央揃えにする必要があります。以下の図に示すように、次のとおりです。

CSS はどのように使用すればよいですか?

リスト 2:

(1)、マージン + 絶対値

子を絶対値に設定し、その上部と右側を 50% に設定すると、子要素レイヤーは図 2 の状況を表示します

次に、要素の margin-top と margin-right を -50% にすると、垂直方向のセンタリングを実現できます。

サンプルコードは次のとおりです:

rrree

(2)、translate + ABS

子を絶対に設定し、その上部と右側を50%に設定してから、子要素のレイヤーを設定します上の図 2 の状況が表示されます。

要素を 50%、移動して 50% 移動すると、図 3 のように垂直方向のセンタリングを実現することもできます。

サンプルコードは以下の通りです:

<!DOCTYPE html>    <head>        <title>center</title>        <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>        <style>                .parent {                width:50%;                height:100px;                border:1px solid black;                position:relative;            }            .child {                position:absolute;                width:50px;                height:50px;                top:50%;                left:50%;                margin-top:-25px;                margin-left:-25px;                background:#22B14C;            }                 </style>    </head>    <body>        <div class="parent">            <div class="child">                             </div>        </div>    </body></html>
ログイン後にコピー

方法 3:

table-cell 属性を使用して簡単に実装できます。

親要素を table-cell に変更すると、table 属性vertical-align:middle を使用して要素を垂直方向に中央揃えにし、子要素 margin:0 atuo を設定して水平方向の中央揃えを実現できます。

追記:

table-cell は、display:table 要素に含める必要があります。table-cell は table に属します。

サンプルコードは次のとおりです:

<!DOCTYPE html>    <head>        <title>center</title>        <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>        <style>                .parent {                width:50%;                height:100px;                border:1px solid black;                position:relative;            }            .child {                position:absolute;                width:50px;                height:50px;                top:50%;                left:50%;                <!--渐进增强-->                -webkit-transform: translate(-50%,-50%);                    -ms-transform: translate(-50%,-50%);                        transform: translate(-50%,-50%);                background:#22B14C;            }                 </style>    </head>    <body>        <div class="parent">            <div class="child">                             </div>                    </div>    </body></html>
ログイン後にコピー

さて、CSS の垂直方向と水平方向の中央揃えについては以上です (フレキシブル レイアウト Flex はこの記事の範囲外です)。

皆さんおやすみなさい〜

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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;について説明します。オートコンプリートの提案を提供し、ユーザーエクスペリエンスの改善、エラーの削減によりフォームを強化する要素。

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

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

&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

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

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

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

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

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

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

Giteeページ静的なWebサイトの展開に失敗しました:単一のファイル404エラーをトラブルシューティングと解決する方法 Giteeページ静的なWebサイトの展開に失敗しました:単一のファイル404エラーをトラブルシューティングと解決する方法 Apr 04, 2025 pm 11:54 PM

GiteEpages静的Webサイトの展開が失敗しました:404エラーのトラブルシューティングと解像度Giteeを使用する

See all articles