• 회원가입
  • 로그인
  • 구글아이디로 로그인

[box] CSS - box-sizing 속성 ★★ - 너비결정방식 (= 길이결정방식 = box-sizing속성 = 박스사이징속성) ※ 요소너비 결정방식 ※ 요소실제너비

목차
  1. box-sizing 예제 - 요소 너비 계산 방식 선택
  2. box-sizing 정의
  3. box-sizing 구문
  4. box-sizing 예제 - <input>요소와 <button> 요소 높이 통일

 

box-sizing 예제 - 요소 너비 계산 방식 선택 

 

<style> 

#hz_cb h2 {color:blue;}

#hz_cb div {

    box-sizing: content-box  /* 요소너비 = width + padding + border */

    width: 400px;

    height: 100px;

    padding: 30px;    

    border: 10px solid blue;

}


#hz_bb h2 {color:red;}

#hz_bb div {

    box-sizing: border-box;  /* 총너비 = width */

    width: 400px;

    height: 100px;

    padding: 30px;    

    border: 10px solid red;

}

</style>

</head>

<body>


<div id="hz_cb">

  <h2>box-sizing: content-box (기본값)</h2>

  <p>padding, border : 총너비에 포함 O</p>

  <div>

    총너비 480px = width 400 + padding (30 x 2) + border (10 x 2)<br>

    홈짱닷컴 (Homzzang.com)

  </div>

</div>

  

<div id="hz_bb">

  <h2>box-sizing: border-box</h2>

  <p>padding, border : 총너비에 포함 X</p>

  <div>

    총너비 400px = width 400<br>

    홈짱닷컴 (Homzzang.com)

  </div>

</div>


결과 보기

 

box-sizing 정의

 

(박스너비 = 박스전체너비 =박스총너비) 결정방식.

즉, 

너비・높이 계산 시, padding・ border 포함여부 결정.

 


 

1.

  • 기본값: content-box
  • 상속여부: X
  • 애니효과: X
  • CSS버전: CSS3
  • JS구문: object.style.boxSizing="border-box"

 

2.

IE8 이상 주요 최신브라우저 지원. (※ 구형 브라우저 경우, 접두사 필요)

  • 구형 Chrome, Safari 경우: -webkit-
  • 구형 Firefox 경우: -moz-

 

 

box-sizing 구문

 

selector {box-sizing: content-box|border-box|initial|inherit;}

 


[속성값]

 

content-box

너비 = (width + 좌우border + 좌우padding)

  • <input type="text">와 <button> 요소 높이 같게 할 때 필요.

 

border-box

너비 = (width)

  • 실제 너비: width + 좌우margin
  • padding, border 값은 너비에서 제외.

 

initial

이 속성의 기본값으로 설정.

 

inherit

부모요소의 속성값 상속.

 

 

box-sizing 예제 - <input>요소와 <button> 요소 높이 통일

 

<style>

.display {float:left; height:30px;line-height:30px; box-sizing: content-box;}

.btn_box {position:relative;}

.btn_box .btn  {width:80px; height:30px; line-height:30px; box-sizing: content-box; overflow:hidden;}

.btn_box .hidden {font-size:29px; position:absolute; right:0px; top:0px; opacity:0; filter: alpha(opacity=0); -ms-filter: alpha(opacity=0); cursor:pointer;}

</style>


<input type="text" id="hz" class="display" readonly>

<div class="btn_box">

    <button type="button" class="btn">파일찾기</button>

    <input type="file" name="hz" class="hidden" onchange="javascript: document.getElementById('hz').value = this.value"/>

</div>

 

결과보기

PS. 주의: box-sizing:content-box 없으면, 높이값이 같아도 실제 높이 다름.



분류 제목
intro CSS - @charset 구문 - 스타일시트 인코딩방식 설정 (= 언어셋지정/문자셋지정 = @charset…
intro CSS - (요소정렬/요소위치/요소이동) CSS 속성 BSET ★★★★★ (= 레이아웃/홈페이지 구조 스타일…
css CSS - (div전체/TD전체/TD셀천체/LI전체)에 링크걸기 (= DIV링크/TD링크/LI링크 = 요소전…
intro CSS - CSS RESET(= CSS리셋 = CSS초기화 = HTML요소초기화)
background CSS - backdrop-filter 속성 - 배경 필터 효과. (= 흐림효과 = 유리효과 = backdr…
공지 CSS - 고급디자인 팁 + 웹디자인 용어 ★★★ [3레벨] 
css CSS - Smooth Scroll (부드러운 스크롤 = 부드럽게이동) ※ 클릭 상하 이동
text CSS - text-fill-color 속성 (비표준) - 텍스트글자색 (= 글자전경색 =text-fill-…
resize CSS - resize 속성 - 사용자의 요소크기 조정권한 지정 (= resize속성 = 리사이즈속성, IE…
func CSS - 함수 종류
func CSS - attr() 함수 - 선택요소의 속성값 반환. (= attr함수 = 어트르함수) ※ 속성값얻기
func CSS - calc() 함수 ★ - 계산 수행해 CSS 속성값 결정. (= calc함수 = 캘크함수) ※ 길…
func CSS - cubic-bezier() 함수 - 이동 속도 변화 (= 입방체 베지에곡선 =cubic-bezie…
func CSS - hsl() 함수 - (색조, 채도, 밝기)로 색상 정의. (= hsl함수 = 에이치에스엘함수/흐슬…
func CSS - hsla() 함수 - (색조, 채도, 밝기, 불투명도)로 색상 정의. (= hsla함수 = 에이치…
gradient CSS - linear-gradient() 함수 ★ - 선형 그레이디언트 배경이미지 (= 선형 그라디언트 …
gradient CSS - radial-gradient() 함수 ★ - 방사형 그레이디언트 배경이미지 (= 방사형 그라디언트…
gradient CSS - repeating-linear-gradient () 함수 - 반복 선형 그레이디언트 ※ 패턴 배경
gradient CSS - repeating-radial-gradient () 함수 - 방사형 그레이디언트 반복 (= 그라디…
func CSS - rgb() 함수 - (빨강,녹색,파랑)으로 색상 정의. (= rgb함수 = 알지비함수)
12/25
목록
찾아주셔서 감사합니다. Since 2012