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

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

 

결과보기


 


분류 제목
selector CSS - ::placeholder 가상선택자 - 플레이스홀더 선택자
column CSS - Multiple Columns - (멀티 컬럼 개괄) ※ 열 나누기 = 단락 나누기
css CSS - IE 전용 CSS핵
func CSS - max() 함수 - 최대값 (= max함수 = 맥스함수)
box CSS - block-size 속성 - 블락 방향으로 요소 크기 지정 (= block-size속성 = 블락…
column CSS - column-fill 속성 - 컬럼 채우기 방식 지정 (= column-fill속성 = 컬럼필속성…
selector CSS - :first-of-type 가상선택자 - 지정타입 첫번째자식요소 (순서선택자/순번선택자/타입선택자…
selector CSS - :out-of-range 가상선택자 - 지정범위밖값 갖는 요소 선택 (=아웃어브레인지선택자, IE…
func CSS - min() 함수 - 최소값 (= min함수 = 민함수)
column CSS - column-rule-color 속성 - 컬럼구분자 색상 지정 (= 컬럼구분바 색깔 = colum…
grid CSS - row-gap 속성(C) - (grid/flex)레이아웃 행간 간격 지정 (= row-gap속성 …
column CSS - column-gap 속성 - 컬럼간의 간격 지정 (= column-gap속성 = 컬럼갭속성)
pagination CSS - 페이징 - 글자 크기 (Pagination Size)
transition CSS - transition-property 속성 - 트랜지션 효과 적용할 속성명 지정 (= transit…
pagination CSS - 페이징 - 링크칸 간격 띄우기 (Space Between Links)
column CSS - column-count 속성 - 컬럼 개수 지정 (= 요소 안 텍스트를 지정 컬럼개수로 구분 = …
column CSS - column-rule-width 속성 - 컬럼구분자 너비 지정 (= 컬럼구분바 두께 = colum…
selector CSS - :nth-last-of-type(n) 가상선택자 - 타입마지막n번째 자식요소 (순서선택자,,타입…
pagination CSS - 페이징 - 빵메뉴 (= Breadcrumbs : 브레드크럼즈 = 메뉴 현재위치 표시)
border CSS - border-top-right-radius 속성 - 테두리상단우측둥글기 지정 (= 보더탑라이트레이…
12/27
목록
찾아주셔서 감사합니다. Since 2012