CSS辞典 box-sizingプロパティの解説
ボックスサイズの算出方法を指定する「box-sizingプロパティ」の使用方法を記載
対応バージョン:CSS3/2.1
対応ブラウザ
data:image/s3,"s3://crabby-images/07604/07604da0bff51214124e04f13efc27bfe59a21be" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:chrome"
data:image/s3,"s3://crabby-images/fb3b4/fb3b46372d27f0bc36d573c070dca31d88bb5221" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:firefox"
data:image/s3,"s3://crabby-images/fedeb/fedebedc0dfca9b8099f518641a50dbb266e894c" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:safari"
data:image/s3,"s3://crabby-images/0dd5d/0dd5d3b6580f8a095a0ef724d993fbbdc8e618db" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:ms edge"
data:image/s3,"s3://crabby-images/4db8d/4db8d0f6cb6284560934a9604e71d1897441e865" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:ms ie"
data:image/s3,"s3://crabby-images/d1039/d1039816042d60fbbdbe7b912a5f228019b26f9b" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:opera"
初期値 | content-box |
適用される要素 | width、heightプロパティを指定できるすべての要素 |
モジュール | CSS Basic User Interface Module Level 3 |
継承 | なし |
概要・使用方法
{ box-sizing: 算出方法;}
「 box-sizingプロパティ」は、ボックスサイズの算出方法指定します。
初期の「content-box」指定では、以下の図のようにpaddingとborderはボックスサイズに含まれません。要素の幅は、width+左右のpadding幅+左右のborder幅です。
data:image/s3,"s3://crabby-images/e2d18/e2d187482fb21d08a843bae35c9d7974590e5e46" alt="box-sizing=content-boxの解説図"
「border-box」を指定すると、ボックスサイズはpaddingとborderを幅と高さに含めます。
data:image/s3,"s3://crabby-images/8e84b/8e84beb3abbaafeb41574de34cb321daf00557af" alt="box-sizing=border-boxの解説図"
「box-sizing」の使い道ですが、レスポンスシブデザインの場合に使用します。レスポンスシブデザインでmargin+border+padding+コンテンツ幅を100%にしたい場合、borderは%指定ができないため要素からコンテンツがはみ出てしまったり、デザインが崩れたりする場合があります。そのような場合は「border-box」にすることで、%指定ができるようになりコンテンツがはみ出る事象を解消することができます。
指定できる値(算出方法)
content-box | ボックスの幅と高さの値に、ボーダーとパディングの値を含めません。 |
border-box | ボックスの幅と高さの値に、ボーダーとパディングの値を含めます。 |
inherit | 親要素のborder-boxの値を引き継ぐ |
HTML文書内で個別でボックスサイズの計算を行うとCSS設計が難しくなるため、全称セレクタリスト(*)でボックスサイズを統一しておくとよいです。古いブラウザー対応させるためにベンダープレフィックスを指定しておきます。
*, *::before, *::after{
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
-ms-box-sizing: border-box;
box-sizing: border-box;
}
サンプルコード
<!DOCTYPE html>
<html lang="ja">
<head>
<title>CSS box-sizingプロパティサンプルページ</title>
<meta charset="uft-8">
<style>
.disp{display:inline-block;}
.contet-box{
box-sizing:content-box;
width: 20em;
height:5em;
margin:1em;
padding:0.5em;
border:5px solid red;
}
.border-box{
box-sizing:border-box;
width: 20em;
height:5em;
margin:1em;
padding:0.5em;
border:5px solid red;
}
.wrapper{
border: 1px dashed blue;
display: inline-block;
}
</style>
</head>
<body>
<div class="wrapper">
<h1>box-sizing:content-box;</h1>
<div class="contet-box"><p>友達の猫は気難しい性格であるため他人が触らせることは滅多にありません。</p></div>
</div>
<div class="wrapper">
<h1>box-sizing:border-box;</h1>
<div class="border-box"><p>友達の猫は気難しい性格であるため他人が触らせることは滅多にありません。</p></div>
</div>
</body>
</html>
box-sizing:content-box;
友達の猫は気難しい性格であるため他人が触らせることは滅多にありません。
box-sizing:border-box;
友達の猫は気難しい性格であるため他人が触らせることは滅多にありません。
chromeブラウザ実行結果
data:image/s3,"s3://crabby-images/f3a5c/f3a5c72ca67c77d9487038a895e8fb3d0a30d865" alt="chrome"
Firefox ブラウザ実行結果
data:image/s3,"s3://crabby-images/e1bc7/e1bc7c42d4bbc634dadcd1fb9da205b523e9297a" alt="Firefox"
edgeブラウザ実行結果
data:image/s3,"s3://crabby-images/5667b/5667bec320cab38dccba7c5680415f4abc401e3b" alt="edge"
operaブラウザ実行結果
data:image/s3,"s3://crabby-images/7ed94/7ed949cb2209d2a527036c43b030550c088ac697" alt="opera"