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

[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>

 

결과보기


 


분류 제목
box CSS - padding 속성 ★ - 안쪽여백 (= padding속성 = 패딩속성)
box CSS - padding-top 속성 - 안쪽여백상단 (= padding-top속성 = 패딩탑속성 = 패딩톱…
box CSS - padding-right 속성 - 안쪽여백우측 (= padding-right속성 = 패딩라이트속…
box CSS - padding-bottom 속성 - 안쪽여백하단 (= padding-bottom속성 = 패딩바텀속…
box CSS - padding-left 속성 - 안쪽여백좌측 (= padding-left속성 = 패딩레프트속성)
position CSS - float 속성 ★★★ - 요소나란히 (= 요소한줄로 = 요소가로로 = 요소옆으로 = float속…
position CSS - clear 속성 ★ - float 해제후 줄바꿈 (= 클리어속성, clear속성, 상속 X)
position CSS - display 속성 ★★★★★ - 요소유형지정 (= 요소성격변 = 요소노출방식 = display속…
position CSS - position 속성 ★★★ - 위치기준대상지정 (= 위치속성 = 포지션속성 = 위치조정 = po…
position CSS - top 속성 ★ - 기준상단 (= 위기준 상단거리 = top속성 = 탑속성/톱속성)
position CSS - right 속성 ★ - 오른쪽기준(= 우측기준) 위치 지정 (= right속성 = 라이트속성) ※…
position CSS - bottom 속성 ★ - 기준하단 (= bottom속성 = 하단기준 = 아래기준 = 바텀속성 = …
position CSS - left 속성 ★ - 왼쪽기준 (= left속성 = 좌측기준 = 레프트속성, 상속 X)
position CSS - z-index 속성 ★ - 요소층수지정 (= 요소상하지정 = 요소상하결정 = 위아래지정 = z-…
position CSS - visibility 속성 ★ - 보임설정 (= 노출설정 = visibility속성 = 비저빌러티속…
position CSS - overflow 속성 ★★ - 범위이탈요소처리 (= 범위넘는요소처리 = 스크롤바 생성 = over…
position CSS - clip 속성 (폐기예고) - 이미지 자르기 (= 일부만 노출 = clip속성 = 클립속성)
css CSS - cursor 속성 - 커서 모양 (= cursor속성 = 커서속성)
intro CSS - !important 키워드 - 당해 속성값 강제 우선적용 (= 우선순위표시 = 느낌표임포턴트)
css CSS - opacity 속성 - 불투명도 (= opacity속성 = 오패서티속성/오페서티속성) ※ 있는데 …
6/25
목록
찾아주셔서 감사합니다. Since 2012