Uri ShakedとMichal Poragが共著したこの記事は、CSS幅と高さの計算の複雑さを掘り下げています。 CSS仕様の広範なデバッグと分析に基づいて、要素寸法の頻繁に使用される動作を解明します。
基本的な概念:
width: 640px;
およびheight: 360px;
結果として640x360ピクセル要素が得られます。ただし、パディングを追加するとこれが変更されます。 padding: 10px;
、レンダリングされたサイズは、デフォルトのcontent-box
box-sizing
のため、660x380pxになります。ボックスモデルは、次のように幅と高さを計算します。
-
幅:
width padding-left padding-right border-left border-right
-
高さ:
height padding-top padding-bottom border-top border-bottom
これは、ブロックレベルの要素に適用されます(例:<div> 、<code><p> 、<code><main></main>
)、自然に拡張して利用可能な幅を埋めます。インライン要素の動作は異なります。
インライン要素ニュアンス:
インライン要素の場合(例、<span></span>
)、 width
とheight
ほとんど無視されます。寸法はコンテンツによって決定されます。インライン要素内でブロック要素をネストすると、インラインの流れが破壊され、この区別が強調されます。また、インライン要素は、 top
とbottom
マージンを無視します。
親子の相互作用:
親子関係は、次元の計算に大きな影響を与えます。
相対単位:パーセンテージは、親要素の寸法に関連しています。
width: 100%;
親の幅を採用します。高さは同様に動作します。パディングとマージン:パーセンテージベースのパディングとマージンは、垂直値であっても、常に親の幅に関連しています。この「パディングハック」は、アスペクト比ボックスを作成するために使用されますが、
aspect-ratio
プロパティが推奨されています。display: inline
およびinline-block
:display: inline;
display: inline-block;
インラインの動作とブロックレベルのボックスモデルの計算を組み合わせて、margin
、width
、height
尊重します。
周期的なパーセンテージサイジング:
宣言された幅を欠く親の中に相対幅(例えば、 33%
)を持つ子要素は、「サイクリックパーセンテージサイジング」シナリオを作成します。ブラウザは、子供の内容に基づいて親の幅を繰り返し計算し、新しく計算された親の幅に比べて子供の割合の幅を適用します。
min-width
、 min-height
、 max-width
、 max-height
:
これらのプロパティは、最小および最大サイズの制限を定義します。明示的な幅(たとえば、 100%
)であっても、 max-width
要素のサイズを制約できます。 width
とmax-width
値を交換すると、親要素が関与している場合、特にdisplay: inline-block;
を使用すると、異なる結果が生じる可能性があります。 。
min()
、 max()
、およびclamp()
:
これらの関数は、メディアクエリなしで応答性のあるサイジングを提供します。
-
min()
:その議論の最小値を返します。 -
max()
:引数の最大値を返します。 -
clamp()
:min()
とmax()
の組み合わせ。
これらの関数は、応答性のある要素の次元を定義する簡潔な方法を提供します。
結論:
CSS幅と高さの計算は驚くほど複雑です。明示的な値が指定されていますが、レンダリングされた寸法は、ボックスモデル、要素タイプ(ブロック対インライン)、親子関係、相対単位、およびその他の要因によって影響を受けます。これらの複雑さを理解することは、正確なレイアウト制御にとって重要です。
著者: Uri ShakedとMichal Porag
以上がCSSの幅と高さの複雑さを調査しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

CSSグリッドは、複雑で応答性の高いWebレイアウトを作成するための強力なツールです。設計を簡素化し、アクセシビリティを向上させ、古い方法よりも多くの制御を提供します。

記事では、レスポンシブデザインにおけるスペースの効率的なアラインメントと分布のためのレイアウト方法であるCSS FlexBoxについて説明します。 FlexBoxの使用量を説明し、CSSグリッドと比較し、ブラウザのサポートを詳細に説明します。

この記事では、ビューポートメタタグ、柔軟なグリッド、流体メディア、メディアクエリ、相対ユニットなど、CSSを使用してレスポンシブWebサイトを作成するための手法について説明します。また、CSSグリッドとフレックスボックスを使用してカバーし、CSSフレームワークを推奨しています

この記事では、要素の寸法の計算方法を制御するCSSボックスサイズのプロパティについて説明します。コンテンツボックス、ボーダーボックス、パディングボックスなどの値と、レイアウト設計とフォームアライメントへの影響について説明します。

記事では、CSS、キープロパティ、およびJavaScriptとの組み合わせを使用してアニメーションの作成について説明します。主な問題は、ブラウザの互換性です。

記事では、3D変換、主要なプロパティ、ブラウザの互換性、およびWebプロジェクトのパフォーマンスに関する考慮事項にCSSを使用して説明します。

この記事では、CSSグラデーション(線形、放射状、繰り返し)を使用して、ウェブサイトのビジュアルを強化し、深さ、フォーカス、および現代の美学を追加します。

記事では、CSSの擬似要素、HTMLスタイリングの強化における使用、および擬似クラスとの違いについて説明します。実用的な例を提供します。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ドリームウィーバー CS6
ビジュアル Web 開発ツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ホットトピック









