ホームページ ウェブフロントエンド CSSチュートリアル CSSの幅と高さの複雑さを調査します

CSSの幅と高さの複雑さを調査します

Mar 27, 2025 am 11:15 AM

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> )、 widthheightほとんど無視されます。寸法はコンテンツによって決定されます。インライン要素内でブロック要素をネストすると、インラインの流れが破壊され、この区別が強調されます。また、インライン要素は、 topbottomマージンを無視します。

親子の相互作用:

親子関係は、次元の計算に大きな影響を与えます。

  • 相対単位:パーセンテージは、親要素の寸法に関連しています。 width: 100%;親の幅を採用します。高さは同様に動作します。

  • パディングとマージン:パーセンテージベースのパディングとマージンは、垂直値であっても、常に親のに関連しています。この「パディングハック」は、アスペクト比ボックスを作成するために使用されますが、 aspect-ratioプロパティが推奨されています。

  • display: inlineおよびinline-block display: inline; display: inline-block;インラインの動作とブロックレベルのボックスモデルの計算を組み合わせて、 marginwidthheight尊重します。

周期的なパーセンテージサイジング:

宣言された幅を欠く親の中に相対幅(例えば、 33% )を持つ子要素は、「サイクリックパーセンテージサイジング」シナリオを作成します。ブラウザは、子供の内容に基づいて親の幅を繰り返し計算し、新しく計算された親の幅に比べて子供の割合の幅を適用します。

min-widthmin-heightmax-widthmax-height

これらのプロパティは、最小および最大サイズの制限を定義します。明示的な幅(たとえば、 100% )であっても、 max-width要素のサイズを制約できます。 widthmax-width値を交換すると、親要素が関与している場合、特にdisplay: inline-block;を使用すると、異なる結果が生じる可能性があります。 。

min()max() 、およびclamp()

これらの関数は、メディアクエリなしで応答性のあるサイジングを提供します。

  • min() :その議論の最小値を返します。
  • max() :引数の最大値を返します。
  • clamp()min()max()の組み合わせ。

これらの関数は、応答性のある要素の次元を定義する簡潔な方法を提供します。

結論:

CSS幅と高さの計算は驚くほど複雑です。明示的な値が指定されていますが、レンダリングされた寸法は、ボックスモデル、要素タイプ(ブロック対インライン)、親子関係、相対単位、およびその他の要因によって影響を受けます。これらの複雑さを理解することは、正確なレイアウト制御にとって重要です。

著者: Uri ShakedとMichal Porag

以上がCSSの幅と高さの複雑さを調査しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

静的フォームプロバイダーの比較 静的フォームプロバイダーの比較 Apr 16, 2025 am 11:20 AM

ここでは、「静的フォームプロバイダー」という用語を埋めてみましょう。あなたはあなたのHTMLを持ってきます

SASSをより速くするための概念の証明 SASSをより速くするための概念の証明 Apr 16, 2025 am 10:38 AM

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

毎週のプラットフォームニュース:HTMLロード属性、主なARIA仕様、およびIFRAMEからShadowDOMへの移動 毎週のプラットフォームニュース:HTMLロード属性、主なARIA仕様、およびIFRAMEからShadowDOMへの移動 Apr 17, 2025 am 10:55 AM

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

HTMLダイアログ要素を使用したいくつかの実践 HTMLダイアログ要素を使用したいくつかの実践 Apr 16, 2025 am 11:33 AM

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

ペーパーフォーム ペーパーフォーム Apr 16, 2025 am 11:24 AM

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

「ポッドキャストにサブスクライブ」リンクはどこにすべきですか? 「ポッドキャストにサブスクライブ」リンクはどこにすべきですか? Apr 16, 2025 pm 12:04 PM

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

それはすべて頭の中にあります:Reactヘルメットを使用してReact Poweredサイトのドキュメントヘッドを管理する それはすべて頭の中にあります:Reactヘルメットを使用してReact Poweredサイトのドキュメントヘッドを管理する Apr 15, 2025 am 11:01 AM

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

独自の非JavaScriptベースの分析をホストするためのオプション 独自の非JavaScriptベースの分析をホストするためのオプション Apr 15, 2025 am 11:09 AM

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

See all articles