CSSの幅と高さの複雑さを調査します
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 サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

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

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

ホットトピック











新しいプロジェクトの開始時に、SASSコンピレーションは瞬く間に起こります。これは、特にbrowsersyncとペアになっている場合は素晴らしい気分です。

今週のプラットフォームニュースのラウンドアップで、Chromeは、Web開発者のロード、アクセシビリティ仕様、およびBBCの動きのための新しい属性を導入します

これは私が初めてHTML要素を見ていることです。私はしばらくの間それを知っていましたが、まだスピンしていませんでした。かなりクールです

購入またはビルドは、テクノロジーの古典的な議論です。自分で物を構築することは、あなたのクレジットカードの請求書にはラインアイテムがないため、安価に感じるかもしれませんが

しばらくの間、iTunesはポッドキャストの大きな犬だったので、「ポッドキャストにサブスクライブ」をリンクした場合:

ドキュメントヘッドはウェブサイトの中で最も魅力的な部分ではないかもしれませんが、それに入るものは間違いなくあなたのウェブサイトの成功にとってそれと同じくらい重要です

サイトの訪問者と使用データを追跡するのに役立つ分析プラットフォームがたくさんあります。おそらく、特にGoogleアナリティクスが広く使用されています
