[CSS] Box Model
11240 ワード
📦Box Model
data:image/s3,"s3://crabby-images/73026/73026d5641bf5ee84f44d5d8d4562ac089e7db15" alt=""
<サイズ>
これらは
🗳️ width
🗳️ height
🗳️ min/max-height/width
.blcok {
width: 100px
height :200px
}
#parent {
width: 100px
height :200px
}
#child {
width: 50%px
min-wid: 100px -> 50%한 값이 100px이하로 줄어들게 되면 더이상 줄어들지 않는다.
height :200px
}
data:image/s3,"s3://crabby-images/cbd72/cbd72aa3c9d1916d72bafb55b21ce3a8e6086a85" alt=""
<余白>
これらは
1つの値
🗳️ margin
/* Apply to all four sides */
margin: 1em;
margin: -3px;
/* vertical | horizontal */
margin: 5% auto;
/* top | horizontal | bottom */
margin: 1em auto 2em;
/* top | right | bottom | left */
margin: 2px 1em 0 auto;
/* Global values */
margin: inherit;
margin: initial;
margin: revert;
margin: unset;
<Value>
#parent {
width: 200px
height: 200px
}
#child {
margin: 30% -> 부모의 width인 200px의 30%의 값을 가지게 된다.
}
🗳️ 境界崩壊(境界相殺)
1.近所の兄弟
ex)boxの上端が10 px、下端が20 pxの場合、2つのboxが重なると、20 pxでマージンが得られる.
data:image/s3,"s3://crabby-images/6d73f/6d73f90ec11fb995bddb091979e39948716bbb91" alt=""
2.親子の間
data:image/s3,"s3://crabby-images/94b53/94b53fa14b0040c95e0fc04b8ea104ec6df059f3" alt=""
3.ブランクブロック
data:image/s3,"s3://crabby-images/29e2f/29e2fab2d38abed7963ae21654d9598774018f13" alt=""
🗳️ padding
<ボーダー>
/* 네 면 모두 적용 */
padding: 1em;
/* 세로방향 | 가로방향 */
padding: 5% 10%;
/* 위 | 가로방향 | 아래 */
padding: 1em 2em 2em;
/* 위 | 오른쪽 | 아래 | 왼쪽 */
padding: 5px 1em 0 2em;
/* 전역 값 */
padding: inherit;
padding: initial;
padding: unset;
🗳️ border
data:image/s3,"s3://crabby-images/2636b/2636b792bf3fc9d5b013faa8d1a62ca6aa773ccf" alt=""
/* 스타일 */
border: solid;
/* 너비 | 스타일 */
border: 2px dotted;
/* 스타일 | 색 */
border: outset #f33;
/* 너비 | 스타일 | 색 */
border: medium dashed green;
/* 전역 값 */
border: inherit;
border: initial;
border: unset;
✅ border vs outline
🗳️ border-radius
border-bottom-right-radius: 5px;
data:image/s3,"s3://crabby-images/90578/905788cd4fd561b72d58fce6ce6f16cf790082d8" alt=""
🗳️ box-sizing
box-sizing: content-box;
width: 100%;
border: solid #5B6DCD 10px;
padding: 5px;
data:image/s3,"s3://crabby-images/1e437/1e437f7a4889effea32d682790f35e0a15a6b089" alt=""
したがって、ボックス全体のサイズを変更したくない場合は、border-boxを指定する必要があります.
<属性値>content-box
デフォルトは
border-box
initial
inherit
🗳️ border-box
box-sizing: border-box;
を使用します.下図では、横長と縦長はそれぞれ300200であるが、borderの30 pxを加えると、実際には360、260である.
data:image/s3,"s3://crabby-images/c3eee/c3eeee2ebc3a9e01697197c7a1ad31b8721a3d93" alt=""
data:image/s3,"s3://crabby-images/fef36/fef361f6e7a62fbeb4d3477ae516d5889d52ac7e" alt=""
✅ border vs outline
cssの上部に次のコードのように宣言する場合は、各要素に属性を与える必要はありません.
* {
box-sizing: content-box;
}
Reference
この問題について([CSS] Box Model), 我々は、より多くの情報をここで見つけました https://velog.io/@songjy377/CSS-Box-Modelテキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol