ホームページ  >  記事  >  ウェブフロントエンド  >  ボックスモデルのCSS実装を詳しく解説

ボックスモデルのCSS実装を詳しく解説

韦小宝
韦小宝オリジナル
2018-03-14 16:31:084485ブラウズ

この記事では、CSS 実装 ボックス モデル について説明します。ボックス モデルの CSS 実装について知らない場合、またはボックス モデルの CSS 実装に興味がある場合は、この記事を見てみましょう。早速、本題に入りましょう。Bar

ボックス モデルは、HTML+CSS の基本的な知識であり、この重要な概念を理解することによってのみ、より適切に入力し、ページをレイアウトすることができます。以下はCSSボックスモデルについて蓄積してきた知識をまとめたもので、初心者の方のお役に立てれば幸いです。

1. CSSボックスモデルの概念

CSS CSSボックスモデルはボックスモデル(Box Model)とも呼ばれ、要素コンテンツ(content)、内側のマージン(padding)、ボーダー(border)、外縁 マージンにはいくつかの要素があります。図に示すように:

ボックスモデルのCSS実装を詳しく解説

図の最も内側のボックスは要素の実際の内容、つまり要素ボックスです。要素ボックスの外側の隣にパディングがあり、その次に境界線が続きます。 、次に最も外側のボックスがマージンとなり、ボックス全体のモデルが形成されます。通常、設定する背景表示領域は、コンテンツ、パディング、境界線の範囲です。外側のマージンは透明であり、周囲の他の要素を妨げません。

すると、要素ボックスの合計幅=要素(要素)の幅+パディングの左右のマージンの値+マージンの左右のマージンの値+左右のマージンの値となります。

要素ボックスの高さの合計 = 要素の高さ + パディングの上下のマージンの値 + 要素の上下の幅国境。

2.CSSの余白の結合(重ね合わせ)

上下に隣接する2つの要素ボックスが縦に交わると余白が結合され、結合された余白の高さがその高さと等しくなります。図

に示すように、外側のマージンの値が大きいほど理解しやすいため、ページ上で実際の状況に遭遇する場合は、この要素を考慮する必要がある場合があります。もちろん、以下に示すように、マージンを結合することにも意味があります:

通常のドキュメント フローでは、ブロック ボックスの垂直方向の余白のみがマージされることに注意してください。インライン ボックス、フローティング ボックス、または 絶対配置 の間のマージンはマージされません。

cssリセットもよく使われます


* {
  margin : 0;
  padding : 0;
}

3. box-sizing属性の紹介

box-sizing属性はユーザーインターフェース属性の1つであり、その理由は次のとおりです。この属性はボックス モデルに関連しており、CSS リセットで使用される可能性があるため、 が導入されました。

box-sizing : content-box|border-box|inherit;

(1) content-boxデフォルト値。これにより、設定された幅と高さの値を要素に適用できます。コンテンツボックス。ボックスの幅にはコンテンツのみが含まれます。

つまり、合計幅 = margin+border+padding+width

(2) border-box 、設定された幅の値は実際にはmarginを除いたborder+padding+elementの合計幅になります。ボックスの幅には、border+padding+contentが含まれます

つまり、合計の幅= margin+width

多くのCSSフレームワークは、ボックスモデルの計算方法を簡素化します。

(3) inherit は、box-sizing 属性の値が親要素から継承されるべきであることを規定します

border-box の使用について:

1 ボックスの幅は 100% です、両側に内部コンテンツが必要です 間隔、この時点でそれを使用することをお勧めします
2 グローバル設定のボーダーボックスは非常に優れています。第一に、それは直感的であり、第二に、追加、追加の必要性を節約できます。 、減算、減算を繰り返します。また、境界線付きのボックスを作成するという重要な機能もあります。通常はパーセント幅を使用します。

4. 実際の開発で遭遇するフレームモデルに関連するアプリケーションと小さな問題。

1 マージンが範囲外です (最初の子要素の margin-top と最後の子要素の margin-bottom が範囲外である問題)

以第一个子元素的margin-top 为例:

当父元素没有边框border时,设置第一个子元素的margin-top值的时候,会出现margin-top值加在父元素上的现象,解决方法有四个:

(1)给父元素加边框border (副作用)

(2)给父元素设置padding值  (副作用)

(3)父元素添加 overflow:hidden (副作用)

(4)父元素加前置内容生成。(推荐)

以第四种方法为例:

.parent {
     width : 500px;
     height : 500px;
     background-color : red;       
}.parent : before {
     content : " ";
     display : table;
}.child {
     width : 200px;
     height : 200px;
     background-color : green;
     margin-top : 50px;
}
<p class="parent">
<p class="child"></p> </p>


2 浏览器间的盒子模型。

(1)ul标签在Mozilla中默认是有padding值的,而在IE中只有margin有值。

(2)标准盒子模型与IE模型之间的差异:

  标准的盒子模型就是上述介绍的那种,而IE模型更像是 box-sizing : border-box; 其内容宽度还包含了border和padding。解决办法就是:在html模板中加doctype声明。

3 用盒子模型画三角形

nbsp;html>
  
    <style>
        .triangle {
            width : 0;
            height: 0;
            border : 100px solid transparent;
            border-top : 100px solid blue; /*这里可以设置border的top、bottom、left、right四个方向的三角*/
        }
    </style>
  
  
    <p></p>
  

页面显示结果为:

以上就是本篇文章的所有内容,大家要是还不太了解的话,可以自己多实现两边就很容易掌握了哦!

相关推荐:

HTML与CSS的盒子模型


CSS布局之盒子模型属性

以上がボックスモデルのCSS実装を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。