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

[table] CSS - table-layout 속성 ★★★ - 테이블 셀, 행 및 열을 레이아웃 (= table-layout속성 = 테이블레이아웃속성)

목차
  1. table-layout 예제 - 너비 결정 방식
  2. table-layout 정의
  3. table-layout 구문
  4. table-layout:fixed 이슈 - 긴 영문 문자열로 인한 레이아웃 깨짐 방지

 

table-layout 예제 - 너비 결정 방식 

 

<style>

table {

  border-collapse: collapse;

  border: 1px solid black;


th,td {

  border: 1px solid black;

}


table.a {

  table-layout: auto;

  width: 200px;  

}


table.b {

  table-layout: fixed;

  width: 200px;  

}


table.c {

  table-layout: auto;

  width: 100%;  

}


table.d {

  table-layout: fixed;

  width: 100%;  

}

</style>


<h2>table-layout: auto; width: 200px:</h2>

<table class="a">

  <tr>

    <th>코딩언어</th>

    <th>기능</th>

    <th>난이도</th>

  </tr>

  <tr>

    <td>HTML</td>

    <td>기본틀</td>

    <td>1</td>

  </tr>

  <tr>

    <td>CSS</td>

    <td>디자인</td>

    <td>2</td>

  </tr>

  <tr>

    <td>JS</td>

    <td>동작기능</td>

    <td>3</td>

  </tr>

</table>


<h2>table-layout: fixed; width: 200px:</h2>

<table class="b">

  <tr>

    <th>코딩언어</th>

    <th>기능</th>

    <th>난이도</th>

  </tr>

  <tr>

    <td>HTML</td>

    <td>기본틀</td>

    <td>1</td>

  </tr>

  <tr>

    <td>CSS</td>

    <td>디자인</td>

    <td>2</td>

  </tr>

  <tr>

    <td>JS</td>

    <td>동작기능</td>

    <td>3</td>

  </tr>

</table>


<h2>table-layout: auto; width: 100%:</h2>

<table class="c">

  <tr>

    <th>코딩언어</th>

    <th>기능</th>

    <th>난이도</th>

  </tr>

  <tr>

    <td>HTML</td>

    <td>기본틀</td>

    <td>1</td>

  </tr>

  <tr>

    <td>CSS</td>

    <td>디자인</td>

    <td>2</td>

  </tr>

  <tr>

    <td>JS</td>

    <td>동작기능</td>

    <td>3</td>

  </tr>

</table>


<h2>table-layout: fixed; width: 100%:</h2>

<table class="d">

  <tr>

    <th>코딩언어</th>

    <th>기능</th>

    <th>난이도</th>

  </tr>

  <tr>

    <td>HTML</td>

    <td>기본틀</td>

    <td>1</td>

  </tr>

  <tr>

    <td>CSS</td>

    <td>디자인</td>

    <td>2</td>

  </tr>

  <tr>

    <td>JS</td>

    <td>동작기능</td>

    <td>3</td>

  </tr>

</table>

 

결과보기

 

table-layout 정의

 

테이블 (셀, 행, 열) 레이아웃하는 데 사용.

 


 

1. 

table-layout: fixed; 속성 장점 2가지

 

① 

테이블이 훨씬 빠르게 렌더링 되는 느낌 줌.

즉,

큰 테이블에서 브라우저가 전체 테이블을 렌더링 할 때까지 사용자는 테이블의 일부를 볼 수 없는데,
table-layout : fixed 사용 시 브라우저가 테이블의 나머지 부분 로드 동안 테이블 상단을 볼 수 있음.

 

너비 지정한 테이블 레이아웃이 긴 영문문자열로 인해 깨지는 현상 차단 가능.

즉,

한글 경우엔 지정 너비 안에서 자연스럽게 줄바꿈하나,

긴 영문 문자열 경우엔 테이블 레이아웃 늘려버리는데,

table-layout:fixed 속성 사용하면 이 현상 차단 가능.

 

2.

  • 기본값: auto
  • 상속여부 : X
  • 애니효과: X
  • CSS버전: CSS2
  • JS구문: object.style.tableLayout="fixed";

 

3.

주요 최신 브라우저 모두 지원.

 

4. MDN table-layout 예제보기

https://developer.mozilla.org/en-US/docs/Web/CSS/table-layout

 

 

table-layout 구문

 

selector {table-layout: auto|fixed|initial|inherit;}

 


[속성값]

 

auto

자동 레이아웃 (기본값).
가장 긴 셀 내용이 셀 너비 결정.

 

fixed

고정 레이아웃. 테이블 및 열 너비는 테이블 및 열 너비 또는 첫 번째 셀 행 너비로 설정. 다른 행의 셀은 열 너비에 영향 안 미침. 첫 번째 행에 너비가 없으면 셀 내부의 내용에 관계없이 열 너비가 테이블에서 동일하게 나뉨.

 

initial

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

 

inherit

부모 요소의 속성값 상속. 

 


table-layout:fixed 이슈 - 긴 영문 문자열로 인한 레이아웃 깨짐 방지

 

<style>

table,th,td {border:1px solid red;}

table {width:100px;}

table.c {table-layout:fixed;}

table.d {table-layout:fixed; word-break:break-all;}

table.e {table-layout:fixed; overflow:hidden;}

</style>

 

 

<table class='a'>

<tr>

    <td>a.홈짱닷컴 홈페이지 제작관리 유지보수 강의</td>

</tr>

</table>


<table class='b'>

<tr>

    <td>b.https://homzzang.com/b/css</td>

</tr>

</table>


<table class='c'>

<tr>

    <td>c.https://homzzang.com/b/css</td>

</tr>

</table>


<table class='d'>

<tr>

    <td>d.https://homzzang.com/b/css</td>

</tr>

</table>


<table class='e'>

<tr>

    <td>e.https://homzzang.com/b/css</td>

</tr>

</table>

 

결과보기


 


분류 제목
text CSS - word-wrap 속성 ★ - 단어줄바꿈 위해 긴단어쪼개기 (= 긴단어깨기 = 긴단어나누기 = w…
outline CSS - outline-color 속성 - 외곽선두께 (= 아웃라인컬러속성 = outline-color속성…
responsive CSS - RES Frameworks - (반응형 프레임워크) - 반응형홈페이지틀
outline CSS - outline-width (아웃라인위드스) - 테두리 외곽 두께 (상속 X) : (IE8)
box CSS - box-sizing 속성 ★★ - 너비결정방식 (= 길이결정방식 = box-sizing속성 = 박…
animation CSS - animation 속성 ★ - 애니메이션 단축속성 (= animation속성 = 애니메이션속성, …
selector CSS - :empty 가상선택자 - 자식/내용 없는 텅 빈 요소 선택 (= :empty선택자 = 엠프티 선…
selector CSS - ::first-line 가상선택자 - 요소의 첫번째라인 선택 (= ::first-line선택자 =…
css CSS - pointer-events 속성 - 마우스이벤트에 대한 반응 여부 (= pointer-events…
text CSS - overflow-wrap 속성 - 줄바꿈 위해 단어 쪼개기 (= overflow-wrap속성 = …
image CSS - enter an Image (이미지 가운데정렬/중앙정렬)
css CSS - 인스타그램(instagram) 배경색 효과
shadow CSS - text-shadow 속성 - 글자 그림자/음영 효과 주기 (= text-shadow속성 = 텍스…
background CSS - background-size 속성 ★ - 배경이미지 크기 (background-size속성 = 백…
selector CSS - ::selection 가상선택자 - 사용자가 선택한 영역 (= ::selection선택자) (가상…
selector CSS - [attribute|=value] 속성선택자 - 해당속성값 또는 뒤에 하이픈 연결된 속성값 보유 …
box CSS - padding-bottom 속성 - 안쪽여백하단 (= padding-bottom속성 = 패딩바텀속…
selector CSS - [attribute*=value] 속성선택자 - 지정 속성값 문자열 포함 모든 요소 (IE7)
text CSS - text-align-last 속성 - 단락마지막라인정렬 (= text-align-last속성 = …
text CSS - text-decoration-line 속성 - 텍스트라인위치종류 (= text-decoration…
18/27
목록
찾아주셔서 감사합니다. Since 2012