検索
ホームページウェブフロントエンドhtmlチュートリアルthings_html/css_WEB-ITnose をセンタリングする

センタリングに関すること

最近、対処が必要なセンタリングの問題がいくつか発生しました。ここでは、発生した問題の概要といくつかの解決策を示します。

水平方向テキストの中央揃え

text-align:center;

要素を水平方向に中央揃えすると、コンテンツがインラインまたはインラインブロックになることがわかります。テキスト以外のシナリオでは、パディングによって実際に同じ効果が得られます。これは内容物に応じて調整できます。そうしないと、外容器の幅が固定されません。

テキストが縦方向中央に配置されます

テキストが 1 行で縦方向中央に配置される場合

line-height: 30px;height: 30px;

複数行の場合は、これを考慮できます

padding: 30px 0;

これ 上下の間隔は同じで、複数行の圧迫はありません

画像は中央に配置されます

ここではいくつかのシナリオを示します 1. コンテナーは相対的に大きく、コンテナと画像の幅と高さが固定されているため、上記のアイデアを使用するのは非常に簡単です。解決は簡単です。インライン + 行の高さまたはインライン + パディング

//css.wrap0 {    height: 300px;    width: 100%;    text-align: center; } .c0{    line-height: 300px;    display: inline-block;}
//dom<div class="wrap0">    <div class="c0">我好</div></div>

2 コンテナは比較的大きいのですが、コンテナと画像の幅と高さが固定されていないため、画像を水平方向にどのように適応的に処理するかは、インライン要素のテキストの中央揃え方法を使用することで実現できますか? 。 垂直方向では、テキストを垂直方向に中央揃えする他の方法 (vertical-align、インライン要素を中央揃えにする) があるかどうかを実際に検討できます。そう考えると、vertical-align は複数の要素の位置合わせ方法なので、別の要素を非表示にすることも検討できるかもしれません。

//css  .wrap1 {    height: 100%;    width: 100%;    position: fixed;    text-align: center; }    .c1 {    height: 100px;    width: 100px;    background-color: gray;    display: inline-block;    vertical-align: middle; } .c2 {     height: 100%;    background-color: green;    display: inline-block;    vertical-align: middle;    width: 0; }
//dom<div class="wrap1">    <div class="c1"></div>    <div class="c2"></div></div>

3 コンテナは比較的小さいですが、コンテンツは比較的大きいです。まず、水平方向の処理方法を見てみましょう。をコンテナ内に配置すると、コンテンツがコンテナの左側に整列されます。理論的には、整列するには内側のコンテナを左側に移動する必要があります。ここで問題となるのは、どのくらい移動する必要があるかということです。

//考虑到方向position = (width[容器] - width[内容])/2

実際には幅の違いの 1/2 です。それで、残りの問題は、どうやってそこまで移動するかということです。 一般的な位置関連のスタイルには、top|left|right|bottom、margin、position、left が含まれます。また、コンテンツの left が 50% に設定されている場合、実際には width[container]/2 の値に基づきます。それが出てきて、width[content]/2を実装したい場合は、コンテンツの外側に要素をネストするだけです。この要素はコンテンツと同じ幅と高さを持ち、コンテンツのmargin-leftを50%に設定します。 width[content]. ]/2 を実現するには、式が負であることを考慮して、margin-left を 50% にする必要があります。コード

 .wrap1 { height: 100px; width: 200px; margin: 0 auto; text-align: center; border: 1px solid red; position: relative; }     .wrap2 { height: 100px; width: 300px; margin: 0 auto; text-align: center; border: 2px solid blue; position: absolute; left: 50%; }    .c1 { width: inherit; height: inherit; background-color: gray; margin-left:-50%; }
 <div class="wrap1">    <div class="wrap2">        <div class="c1"></div>    </div></div>
を直接見ることができます。

ここに落とし穴があります。c1 要素が inline-block スタイルの場合はどうなりますか?

同時に、この効果を垂直方向に実現したい場合はどうなりますか? 、これをしてください。 上記の方法は簡単に思いつくので、ぜひ試してみてください。 実際、これは不可能です。 margin-top の値は、親要素の高さではなく幅に基づいて計算されます。それで。 。 。 。 特別な方法で計算方法を変更することもできます。たとえば、マージンを親要素の高さに基づいて計算すると、次のコードを上記の Wrap1 スタイルに追加するだけで済みます。

 -webkit-writing-mode: vertical-rl; /* for browsers of webkit engine */ writing-mode: tb-rl; /* for ie */

このスタイルを使用しない場合は、js の組み合わせを使用してマージン値を計算することもできます

もう少し拡張

実際、位置を比例的に計算する場合は、CSS3 でtranslate を使用すると、DOM 構造がより簡潔になります。 まず、コードを見てみましょう。コンテナがコンテンツより大きい場合:

 .wrap1 { width: 200px; height: 300px; margin: 300px auto; position: relative; border: 1px solid red; }    .c1 { width: 100px; height: 200px; position: absolute; top: 50%; left: 50%; background-color: gray; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); }
<div class="wrap1">    <div class="c1"></div></div>

上記のコードは、コンテンツがコンテナより大きい場合にも適用できます

リファレンス

  1. CSS 書き込みモード
  2. マージン系列の割合
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
自己閉鎖タグとは何ですか?例を挙げてください。自己閉鎖タグとは何ですか?例を挙げてください。Apr 27, 2025 am 12:04 AM

セルフクロージングのlandxmlareTagstatemtatemsem onedinedingsingaseparateclosingtag、SimmarifiedMarkupStructureanddendingCodingInefciency.1)areEssentionalinforementswithoutcontent、2)

HTMLを超えて:Web開発のための重要なテクノロジーHTMLを超えて:Web開発のための重要なテクノロジーApr 26, 2025 am 12:04 AM

強力な機能と優れたユーザーエクスペリエンスを備えたWebサイトを構築するには、HTMLだけでは十分ではありません。次のテクノロジーも必要です。JavaScriptは、Webページに動的とインタラクティブ性を与え、リアルタイムの変更がDOMを操作することで達成されます。 CSSは、美学とユーザーエクスペリエンスを向上させるために、Webページのスタイルとレイアウトを担当しています。 React、Vue.JS、Angularなどの最新のフレームワークとライブラリは、開発効率とコード組織構造を改善します。

HTMLのブール属性とは何ですか?いくつかの例を挙げてください。HTMLのブール属性とは何ですか?いくつかの例を挙げてください。Apr 25, 2025 am 12:01 AM

ブール属性は、値なしでアクティブ化されるHTMLの特別な属性です。 1.ブール属性は、無効化された入力ボックスを無効にするなど、存在するかどうかによって、要素の動作を制御します。 2.彼らの実用的な原則は、ブラウザが異なっているときに属性の存在に応じて要素の動作を変更することです。 3.基本的な使用法は、属性を直接追加することであり、高度な使用法はJavaScriptを介して動的に制御できます。 4.一般的な間違いは、値を設定する必要があると誤って考えており、正しい執筆方法は簡潔にする必要があります。 5.ベストプラクティスは、コードを簡潔に保ち、ブールのプロパティを合理的に使用して、Webページのパフォーマンスとユーザーエクスペリエンスを最適化することです。

HTMLコードをどのように検証できますか?HTMLコードをどのように検証できますか?Apr 24, 2025 am 12:04 AM

HTMLコードは、オンラインバリデーター、統合ツール、自動化されたプロセスを使用するとクリーンになります。 1)w3cmarkupvalidationserviceを使用して、HTMLコードをオンラインで確認します。 2)リアルタイム検証のためにVisualStudiocodeにhtmlhint拡張機能をインストールして構成します。 3)HTMLTIDYを使用して、建設プロセスでHTMLファイルを自動的に検証およびクリーニングします。

HTML対CSSおよびJavaScript:Webテクノロジーの比較HTML対CSSおよびJavaScript:Webテクノロジーの比較Apr 23, 2025 am 12:05 AM

HTML、CSS、およびJavaScriptは、最新のWebページを構築するためのコアテクノロジーです。1。HTMLはWebページ構造を定義します。2。CSSはWebページの外観に責任があります。

マークアップ言語としてのHTML:その機能と目的マークアップ言語としてのHTML:その機能と目的Apr 22, 2025 am 12:02 AM

HTMLの機能は、Webページの構造とコンテンツを定義することであり、その目的は、情報を表示するための標準化された方法を提供することです。 1)HTMLは、タイトルやパラグラフなどのタグや属性を使用して、Webページのさまざまな部分を整理しています。 2)コンテンツとパフォーマンスの分離をサポートし、メンテナンス効率を向上させます。 3)HTMLは拡張可能であり、カスタムタグがSEOを強化できるようにします。

HTML、CSS、およびJavaScriptの未来:Web開発動向HTML、CSS、およびJavaScriptの未来:Web開発動向Apr 19, 2025 am 12:02 AM

HTMLの将来の傾向はセマンティクスとWebコンポーネントであり、CSSの将来の傾向はCSS-in-JSとCSShoudiniであり、JavaScriptの将来の傾向はWebAssemblyとServerLessです。 1。HTMLセマンティクスはアクセシビリティとSEO効果を改善し、Webコンポーネントは開発効率を向上させますが、ブラウザの互換性に注意を払う必要があります。 2。CSS-in-JSは、スタイル管理の柔軟性を高めますが、ファイルサイズを増やす可能性があります。 CSShoudiniは、CSSレンダリングの直接操作を可能にします。 3. Webassemblyブラウザーアプリケーションのパフォーマンスを最適化しますが、急な学習曲線があり、サーバーレスは開発を簡素化しますが、コールドスタートの問題の最適化が必要です。

HTML:構造、CSS:スタイル、JavaScript:動作HTML:構造、CSS:スタイル、JavaScript:動作Apr 18, 2025 am 12:09 AM

Web開発におけるHTML、CSS、およびJavaScriptの役割は次のとおりです。1。HTMLは、Webページ構造を定義し、2。CSSはWebページスタイルを制御し、3。JavaScriptは動的な動作を追加します。一緒に、彼らは最新のウェブサイトのフレームワーク、美学、および相互作用を構築します。

See all articles

ホット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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、