検索
ホームページウェブフロントエンドhtmlチュートリアルCSSでのボックスサイジングの簡単な説明(標準ボックスモデルと奇妙なボックスモデル)_html/css_WEB-ITnose

今日、レイアウトを行うプログラムを書いているときに、CSS のボックス モデルに関する問題に遭遇しました。私は頭が悪く、文章がわかりにくいです。どうすればいいでしょうか? それで、自分でプログラムのテストを書いたのですが、その効果を見て、私は突然理解しました。以下に簡単に説明しますが、表面的かもしれません。しかし、フロントエンドの友人たちの助けになれば幸いです。

まず、box-sizing の値について説明します。box-sizing には、inheirt、content-box (標準ボックス モデル)、border-box (非標準ブラウザの奇妙なボックス モデル) の 3 つのオプションの値があります。 ie6) );

まず最初の値 content-box について説明します。これは box-sizing のデフォルト値です。これは、要素が実際に占めるスペースの幅 = 設定した幅 (幅) + 境界線 + 内部のスペースを意味します。 div の幅を 100px に設定すると、この div の境界線と間隔を設定すると、境界線と間隔が外側に広がります。実際の div の実際の幅は 100px より大きくなります。上記のコードと図は一目瞭然です。

まず、幅と高さが 100px の div を定義し、box-sizing を content-box に設定し、背景を赤に設定します。強調表示するには、青い背景に配置します。

<div id="bx1" style="width:300px;height:300px;background:blue;">        <div id="bx2" style="width:100px;height:100px;background:red;margin:0px auto;box-sizing:content-box;"></div></div>

次のように表示されます:

比較しやすいように、新しい div を追加します。前の div との唯一の違いは、黄色の 10 ピクセルを追加したことです。 Border;

<div id="bx1" style="width:300px;height:300px;background:blue;">        <div id="bx2" style="width:100px;height:100px;background:red;margin:0px auto;box-sizing:content-box;"></div>        <div id="bx3" style="width:100px;height:100px;background:red;margin:10px auto; box-sizing:content-box;border:10px solid yellow"></div></div>

結果は図に示すように、境界線が div の外側に拡張されます。

新しく追加した div に 10 ピクセルのパディングを追加します。 図に示すように、パディングも外側に拡張されます。 なぜ「hello」の位置に注目してください。 」。

#bx3{padding:10px;}

さて、1 つの属性についての話は終わったので、もう 1 つの属性であるボーダーボックスの話から始めましょう。元の div のボックス サイズをボーダー ボックスに変更します。

ボーダーボックスが内側に拡張されます。 box-sizing を border-box に設定すると、要素が実際に占めるスペースの幅は、border と spacing を設定した場合、内側に拡張されます。元の例をもう一度見てみましょう。 (強迫性障害患者であること、そして私はまだ完璧を追求していることをお許しください)

<div id="bx1" style="width:300px;height:300px;background:blue;">        <div id="bx2" style="width:100px;height:100px;background:red;margin:0px auto;color:white;box-sizing:border-box;">hello</div></div>

境界線と間隔のない最初の画像:

これで、比較のために新しい div が追加されました。元の div との唯一の違いです。幅が 10 ピクセルの黄色の境界線がさらにあるということです

<div id="bx1" style="width:300px;height:300px;background:blue;">        <div id="bx2" style="width:100px;height:100px;background:red;margin:0px auto;color:white;box-sizing:border-box;">hello</div>        <div id="bx3" style="width:100px;height:100px;background:red;margin:0px auto;color:white;box-sizing:border-box;border:10px solid yellow">hello</div></div>

結果は次のようになります: 境界線は内側に拡張します

次に、div に 10 ピクセルの内側マージンを追加します

#bx3{padding:10px;}

結果は次のようになります。内側のマージンが内側に移動して拡張します。「hello」の位置に注意してください。

ここで、皆さんはこれら 2 つの属性について明確にする必要があると思います。

まとめると、box-sizing には context-box、border-box、inherit の 3 つの値があります。Content-box は box-sizing のデフォルト値であり、要素が実際に占めるスペースの幅 = width を意味します。 (幅) + 境界線 + 内側の間隔を設定します。div の幅を設定した後、境界線と間隔を追加し、境界線と間隔を外側に拡張します。 border-box 要素が実際に占めるスペースの幅は、設定した幅と同じになります。ボーダーとスペースが設定されている場合、ボーダーとスペースは内側に広がります。継承属性に関しては、それが持つ属性をすべて継承することを誰もが知っているはずです。ほんの小さなことだったけど、とても長くて、最後に世界の元祖完璧主義者で強迫性障害の患者さんたちに問いかけました。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
HTML、CSS、およびJavaScriptの理解:初心者向けガイドHTML、CSS、およびJavaScriptの理解:初心者向けガイドApr 12, 2025 am 12:02 AM

webdevelopmentReliesOnhtml、css、andjavascript:1)htmlStructuresContent、2)cssStylesit、および3)Javascriptaddsinteractivity、形成、

HTMLの役割:Webコンテンツの構造HTMLの役割:Webコンテンツの構造Apr 11, 2025 am 12:12 AM

HTMLの役割は、タグと属性を使用してWebページの構造とコンテンツを定義することです。 1。HTMLは、読みやすく理解しやすいようなタグを介してコンテンツを整理します。 2。アクセシビリティとSEOを強化するには、セマンティックタグなどを使用します。 3. HTMLコードの最適化により、Webページの読み込み速度とユーザーエクスペリエンスが向上する可能性があります。

HTMLとコード:用語を詳しく見るHTMLとコード:用語を詳しく見るApr 10, 2025 am 09:28 AM

htmlisaspecifictypeofcodefocuseduructuringwebcontent

HTML、CSS、およびJavaScript:Web開発者に不可欠なツールHTML、CSS、およびJavaScript:Web開発者に不可欠なツールApr 09, 2025 am 12:12 AM

HTML、CSS、およびJavaScriptは、Web開発の3つの柱です。 1。HTMLは、Webページ構造を定義し、などなどのタグを使用します。2。CSSは、色、フォントサイズなどのセレクターと属性を使用してWebページスタイルを制御します。

HTML、CSS、およびJavaScriptの役割:コアの責任HTML、CSS、およびJavaScriptの役割:コアの責任Apr 08, 2025 pm 07:05 PM

HTMLはWeb構造を定義し、CSSはスタイルとレイアウトを担当し、JavaScriptは動的な相互作用を提供します。 3人はWeb開発で職務を遂行し、共同でカラフルなWebサイトを構築します。

HTMLは初心者のために簡単に学ぶことができますか?HTMLは初心者のために簡単に学ぶことができますか?Apr 07, 2025 am 12:11 AM

HTMLは、簡単に学習しやすく、結果をすばやく見ることができるため、初心者に適しています。 1)HTMLの学習曲線はスムーズで簡単に開始できます。 2)基本タグをマスターして、Webページの作成を開始します。 3)柔軟性が高く、CSSおよびJavaScriptと組み合わせて使用​​できます。 4)豊富な学習リソースと最新のツールは、学習プロセスをサポートしています。

HTMLでの開始タグの例は何ですか?HTMLでの開始タグの例は何ですか?Apr 06, 2025 am 12:04 AM

Anexampleapalofastartingtaginhtmlis、それはaperginsaparagraph.startingtagsaresentionentientiontheyinitiateelements、definetheirtypes、およびarecrucialforurturingwebpagesandcontingthomedomを構築します。

CSSのフレックスボックスレイアウトを使用して、メニューの点線のラインセグメンテーション効果のセンターアラインメントを実現する方法は?CSSのフレックスボックスレイアウトを使用して、メニューの点線のラインセグメンテーション効果のセンターアラインメントを実現する方法は?Apr 05, 2025 pm 01:24 PM

メニューで点線のラインセグメンテーション効果を設計する方法は?メニューを設計するときは、通常、皿の名前と価格の間に左右に合わせることは難しくありませんが、真ん中の点線またはポイントはどうですか...

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

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

SublimeText3 Mac版

SublimeText3 Mac版

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

メモ帳++7.3.1

メモ帳++7.3.1

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

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

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

EditPlus 中国語クラック版

EditPlus 中国語クラック版

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

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン