Text 속성 - by. UXKM

요약 설명

CSS 텍스트는 줄 바꿈, 자리 맞추기 및 정렬, 공백 처리 및 텍스트 변환과 같은 텍스트 조작을 수행하는 방법을 정의하는 CSS 모듈입니다.

text-align 속성

text-align 속성은 텍스트의 수평 방향 정렬을 설정합니다.
text-align 속성으로 설정된 정렬 방향은 text-direction 속성과는 상관없이 우선적으로 적용됩니다.

  1. left : 박스의 왼쪽 정렬.
  2. right : 박스의 오른쪽 정렬.
  3. center : 박스의 중앙 정렬.
  4. justify : 텍스트는 마지막 줄을 제외하고 양쪽 정렬 (자동 줄바꿈시 오른쪽 경계선 부분 정리)

vertical-align 속성

HTML 요소 내의 인라인(inline)요소와 인라인 블럭(inline-block)요소의 수직 방향 정렬을 설정합니다.
요소 자체만을 정렬하고, 내용에는 영향을 미치지 않습니다. (table cell에 적용할 때는 제외)
table cell에 적용할 때는 내용에 영향을 미칩니다.
vertical-align은 정렬하려는 요소를 다른 인라인 요소에 상대적으로 정렬합니다.
같은 줄에서 인라인 요소의 크기에 따라 높낮이가 달라질 수 있고, 그 줄에 있는 line-height 설정에 따라서도 달라질 수 있습니다.
대부분 부모 요소에 상대적으로 정렬합니다.

부모 기준 값 : 이 값은 요소를 부모 요소를 기준으로 세로로 정렬합니다.

  1. baseline : 기본값으로 부모 요소의 기준 선(baseline)에 맞춤.
  2. middle : 부모 요소 중앙에 위치. 인라인요소를 줄에서 가장 큰 요소의 중간에 정렬하지 않고 가장 작은 소문자 x 높이의 중앙에 정렬합니다.
  3. sub : 부모의 아래첨자 기준선에 맞춤.
  4. super : 부모의 위첨자 기준선에 맞춤.
  5. text-top : 요소의 맨 위를 부모 font의 맨 위에 맞춤.
  6. text-bottom : 요소의 맨 아래를 부모 font의 맨 아래에 맞춤.
  7. 길이값(px, cm등) : 0px는 baseline과 같은 값.
  8. %(백분율) : line-height(줄간격)의 백분율, 0%는 baseline과 같은 값.

라인 기준 값 : 전체 라인을 기준으로 요소를 세로로 정렬합니다. 기준선이없는 요소의 경우 아래쪽 여백 가장자리가 대신 사용됩니다.

  1. top : 요소의 상단과 하위 항목을 전체 줄의 상단(가장 큰 요소의 맨 위)과 정렬합니다.
  2. bottom : 요소의 아래쪽과 그 하위 항목을 전체 줄의 아래쪽(가장 낮은 요소)에 맞춥니다.

테이블 셀의 값

  1. baseline(그리고 sub, super, text-top, text-bottom, length, %) : 셀의 기준선을 기준선이 정렬 된 행에있는 다른 모든 셀의 기준선과 정렬합니다.
  2. top : 셀의 위쪽 패딩 가장자리를 행의 위쪽에 맞춥니다.
  3. middle : 행 내에서 셀의 패딩 상자를 가운데에 맞춥니다.
  4. bottom : 셀의 아래쪽 패딩 모서리를 행의 아래쪽에 맞춥니다.

letter-spacing 속성

letter-spacing 속성은 텍스트 내에서 글자 사이의 간격(자간)을 설정합니다.

  1. normal : 현재 글꼴의 일반적인 문자 간격입니다.
  2. length : 문자 사이의 기본 공백 외에 추가 문자 간 공백 을 지정 합니다. 값은 음수 일 수 있지만 구현 별 제한이있을 수 있습니다. 사용자 에이전트는 텍스트를 정당화하기 위해 문자 간 공간을 더 늘리거나 줄일 수 없습니다.

word-spacing 속성

word-spacing 속성은 텍스트 내에서 단어 사이의 간격을 설정합니다.
letter-spacing 속성과는 달리 문자 간의 간격이 아닌 단어 간의 간격을 기준으로 설정합니다.
참조 : 일부 스크린리더기에서는 양수 또는 음수 word-spacing값이 크면 스타일링이 적용된 문장을 읽을 수 없게됩니다.

  1. normal : 현재 글꼴 또는 브라우저에 의해 정의 된 일반적인 단어 간격입니다.
  2. length : 글꼴로 정의 된 고유 한 단어 간 간격 외에 추가 간격을 지정합니다.

word-break 속성

단어의 분리(줄바꿈)를 어떻게 할 것인지 결정하는 속성입니다.
줄바꿈을 할 때 단어 기준으로 할 지 글자 기준으로 할 지 정하는 속성입니다.
반응형 웹디자인의 경우 가로 크기가 작을 때를 대비해서 word-break의 속성값을 break-all로 정하는 것이 좋습니다.
참고 : 중국어/일본어/한글의 경우 W3C문서에서 CJK(Chinese, Japanes, Korean 의 약자)로 사용하고 있습니다.

줄 바꿈은 허용된 중단점에서 수행(soft wrap opportunity) 되는 것이며, 모든 속성이 기본값이라는 전제하에 줄 바꿈은 대부분의 non-CJK(CJK 이외의 문자)의 경우 '공백(띄어쓰기)'에서, CJK의 경우 '음절'에서 수행됩니다.
값은 normal(기본값), break-all, keep-all 이 있습니다. (keep-all 의 경우 IE에서는 계속 지원하였으나 webkit에서는 15년 6월부터 지원하였습니다.)

  1. normal : 기본값으로 CJK 문자는 글자(음절) 기준으로, CJK 이외의 문자는 단어 또는 공백(띄어쓰기, 하이픈'-') 기준으로 줄바꿈합니다.
  2. keep-all : 공백(띄어쓰기, 하이픈’-‘, 그 외 기호) 기준으로 줄바꿈합니다.(CJK에만 적용됨)
  3. break-all : 글자(음절) 기준으로 줄바꿈합니다.
  4. break-word : 단어 기준으로 줄바꿈합니다.(IE에서는 지원 안 함)

요약 설명

W3C에서 모든 어휘 자원(w3의 모든 [UAX14] 유니코드 내용)을 제공하는 것이 아니기 때문에 CSS는 줄 바꿈이 허용되는 곳을 완전히 정의하지 않으며 예외 사항이 존재할 수 있습니다.
태국어, 라오어 및 크메르어와 같은 언어는 단어를 구분하는데 공백이나 구두점을 사용하지 않습니다.(음절 사이사이를 기반으로 한다는 정의도 없습니다.)
결과적으로 그러한 텍스트의 중단점 수행 기회를 식별하기 위해서는 어휘 자원이 필요합니다.

word-wrap 속성

박스의 가로 영역을 넘친 단어 내에서 임의의 분리 여부를 결정
넘친 단어를 줄 바꿈 하고 싶다면, word-wrap 속성의 값을 바꾸면 됩니다.
이때, 넘친 단어의 임의의 분리는 음절에서 발생하며 white-space 속성이 기본 값(normal) 일 때만 적용됩니다.
word-wrap 속성의 값은 normal(기본값), break-word 가 있습니다.
줄바꿈을 할 때 word-break속성과 word-wrap속성을 같이 사용하면 좀 더 원하는 결과를 얻게 됩니다.

  • 예)줄바꿈을 글자 단위로 하면 word-wrap: break-word; word-break: break-all;
  • 예)줄바꿈을 단어 단위로 하면 word-wrap: break-word; word-break: keep-all;
  1. normal : 기본값으로 글자가 길어도 끊어지지 않고 한 줄에 계속 표시
  2. break-word : 강제로 끊어서 줄바꿈 함

white-space 속성

HTML 요소 내의 여백을 설정함.

  1. normal : 기본값으로 공백을 여러개 넣어도 공백 1개만 표시, 글이 길어지면 텍스트가 자동 줄바꿈 됨(wrap).
  2. nowrap : 공백을 여러개 넣어도 1개만 표시, 텍스트가 길어도 줄바꿈 되지 않고 같은 줄에 계속 표시.
  3. pre : 공백을 코드에 있는 그대로 표시함. <pre>요소처럼 행동함. 코드에 줄바꿈이 없다면 줄바꿈이 되지 않음.
  4. pre-wrap : 공백을 코드에 있는 그대로 표시함. 코드에 줄바꿈이 없어도 자동 줄바꿈이 됨. IE8+ 부터 지원.
  5. pre-line : 공백을 여러개 넣어도 1개만 표시. 코드에 줄바꿈이 없어도 자동 줄바꿈이 되며, 코드에 줄바꿈이 있을 때도 그대로 표시. IE8+ 부터 지원.

text-indent 속성

text-indent 속성은 단락의 첫 줄에 들여쓰기할지 안 할지를 설정합니다.
웹 페이지에서 단락은 기본적으로 들여쓰기가 설정되어 있지 않습니다.

  1. normal : 기본값으로 기본 공란을 재설정. 현재 글꼴 및 브라우저에 의해 정의 된 일반적인 단어 간격.
  2. length : px, em, cm등으로 지정. (음수값 허용)
  3. percentage : 간격을 백분율(%)로 지정.

text-decoration 속성

text-decoration 속성은 텍스트에 여러 가지 효과를 설정하거나 제거하는데 사용합니다.
text-decoration 속성값을 none으로 설정하여 링크(link)가 설정된 텍스트의 밑줄을 제거하는데 자주 사용합니다.
text-decoration 속성값은 CSS Text Decoration Module Level 3 해당 사양에서 'text-decoration-line'으로 새롭게 정의.

  1. none : 기본값으로 밑줄이 없는 보통 글자.
  2. underline : 글자 아래에 밑줄.
  3. overline : 글자 위에 줄이 그어짐.
  4. line-through : 글자 중간에 줄이 그어짐.

text-transform 속성

text-transform 속성은 텍스트에 포함된 영문자에 대한 대소문자를 설정합니다.
이 속성은 텍스트에 포함된 모든 영문자를 대문자나 소문자로 변경시켜 줍니다.
또한, 단어의 첫 문자만을 대문자로 변경시킬 수도 있습니다.
text-transform 속성은 한글에는 영향을 주지 않으며, 오직 영문자에만 적용됩니다.

  1. none : 기본값으로, 텍스트를 html 코드에 있는 그대로 읽음.
  2. capitalize : 각 단어의 첫 번째 문자를 대문자로 만듦. (예: Cascading Style Sheets.)
  3. uppercase : 모든 문자를 대문자로 바꿈. (예: CASCADING STYLE SHEETS.)
  4. lowercase : 모든 문자를 소문자로 바꿈. (예: cascading style sheets.)

text-overflow 속성

부모 영역을 벗어난 wrapping(자동줄바꿈)이 되지 않은 텍스트의 처리 방법을 정의합니다. 이 프로퍼티를 사용하기 위해서는 아래의 조건이 필요합니다.
width 프로퍼티가 지정되어 있어야 한다. 이를 위해 필요할 경우 block 레벨 요소로 변경하여야 합니다.
자동 줄바꿈을 방지하려면 white-space 프로퍼티를 nowrap으로 설정합니다.
overflow 프로퍼티에 반드시 "visible" 이외의 값이 지정되어 있어야 합니다.

  1. clip : 영역을 벗어난 텍스트를 표시하지 않는다. (기본값)
  2. ellipsis : 영역을 벗어난 텍스트를 잘라내어 보이지 않게 하고 말줄임표(…)를 표시한다.

direction 속성

direction 속성은 텍스트가 써지는 방향을 설정합니다.
웹 페이지에서 텍스트는 기본적으로 왼쪽에서 오른쪽 방향으로 써집니다.
direction 속성이 left-to-right(ltr)일 때는 기본 설정처럼 텍스트가 왼쪽에서 오른쪽 방향으로 써집니다.
하지만, direction 속성이 right-to-left(rtl)일 때는 텍스트가 반대 방향인 오른쪽에서 왼쪽 방향으로 써집니다.
아랍어는 한글이나 영어와는 달리 오른쪽에서 왼쪽 방향으로 텍스트를 읽고 쓰는 언어입니다.
따라서 아랍어와 같이 텍스트를 반대 방향으로 쓰는 언어를 나타낼 때는 텍스트가 써지는 방향을 direction 속성을 사용하여 변경해 줘야 합니다.

  1. ltr : 기본값으로 왼쪽에서 오른쪽으로 이동.
  2. rtl : 오른쪽에서 왼쪽으로 이동.

text-shadow 속성

text-shadow 속성은 텍스트에 그림자 효과를 설정합니다.
text-shadow 속성은 쉼표(,)로 구분하여 여러 개의 텍스트 그림자를 적용 할 수 있습니다.

  1. none : 글림자 효과를 없앱니다.
  2. initial : 기본값으로 설정합니다.
  3. inherit : 부모 요소의 속성값을 상속받습니다.
  4. offset-x : 그림자의 수평 거리를 정합니다. (필수)
  5. offset-y : 그림자의 수직 거리를 정합니다. (필수)
  6. blur-radius : 흐림 정도를 정합니다. (선택 : 값을 정하지 않으면 0)
  7. color : 색을 정합니다. (선택 : 값을 정하지 않으면 브라우저 기본값)