CSS 박스 정렬 모듈 레벨 3

W3C 작업 초안,

이 문서에 대한 추가 정보
이 버전:
https://www.w3.org/TR/2026/WD-css-align-3-20260130/
최신 공개 버전:
https://www.w3.org/TR/css-align-3/
에디터스 드래프트:
https://drafts.csswg.org/css-align/
역사:
https://www.w3.org/standards/history/css-align-3/
피드백:
CSSWG 이슈 저장소
명세 내 인라인
편집자:
Elika J. Etemad / fantasai (Apple)
Tab Atkins Jr. (Google)
이 명세에 대한 편집 제안:
GitHub 에디터

요약

이 모듈은 CSS의 박스 레이아웃 모델(블록 레이아웃, 테이블 레이아웃, 플렉스 레이아웃, 그리드 레이아웃)에서 컨테이너 내 박스 정렬과 관련된 기능을 포함합니다. (텍스트 및 인라인 레벨 콘텐츠의 정렬에 대해서는 [CSS-TEXT-3][CSS-INLINE-3]에서 정의되어 있습니다.)

CSS는 구조화된 문서(HTML, XML 등)가 화면, 인쇄물 등에 렌더링 되는 방식을 기술하는 언어입니다.

이 문서의 상태

이 섹션은 문서가 출판될 당시의 상태를 설명합니다. 최신 W3C 출판물 목록과 기술 보고서의 최신 버전은 W3C 표준 및 초안 색인에서 확인할 수 있습니다.

이 문서는 CSS 작업 그룹에서 권고안 트랙을 통해 작업 초안으로 출판되었습니다. 작업 초안으로 출판된다고 해서 W3C와 회원의 승인/지지를 의미하지는 않습니다.

이 문서는 초안이며, 언제든지 갱신, 교체 또는 다른 문서로 대체될 수 있습니다. 이 문서를 진행 중인 작업 이외의 용도로 인용하는 것은 적절하지 않습니다.

피드백은 GitHub 이슈 등록(권장) 방식으로 제출해 주세요. 제목에 “css-align” 규격 코드를 포함해 예시와 같이 남겨 주세요: “[css-align] …의견 요약…”. 모든 이슈와 의견은 아카이브됩니다. 또는, 피드백은 (아카이브됨) 공개 메일링 리스트 www-style@w3.org로 보낼 수도 있습니다.

이 문서는 2025년 8월 18일 W3C 절차 문서에 따라 관리됩니다.

이 문서는 W3C 특허 정책에 따라 운영되는 그룹에서 작성되었습니다. W3C는 그룹의 결과물과 관련해 공개 특허 공지 목록을 관리하고 있습니다. 해당 페이지에는 특허 공지 방법에 대한 안내도 포함돼 있습니다. 특정 특허에 대해 실제 정보를 가진 개인은, 그 특허가 필수 청구항을 포함한다고 판단하는 경우, W3C 특허 정책 섹션 6에 따라 정보를 공개해야 합니다.

다음 기능들은 위험에 처할 수 있으며, CR 기간 중에 삭제될 수 있습니다:

“위험에 처함”은 W3C 프로세스 용어로서, 반드시 기능이 삭제되거나 지연될 위험이 있다는 의미는 아닙니다. 해당 기능이 WG에서 상호 운용성을 갖추기 어려울 것으로 판단될 때 표시하며, 필요한 경우 후보 권고안 단계로 전환할 때 기능을 삭제할 수 있도록 합니다. 먼저 기능을 뺀 새로운 후보 권고안을 발행하지 않고도 기능을 삭제할 수 있습니다.

1. 소개

CSS 레벨 1과 2에서는 text-align을 사용하여 텍스트 정렬과 auto 마진을 균형 있게 맞춰 블록 정렬을 할 수 있었습니다. 하지만 테이블 셀을 제외하면, 수직 정렬은 불가능했습니다. CSS가 더 많은 기능을 추가함에 따라, 박스를 다양한 차원에서 정렬할 수 있는 능력이 더욱 중요해집니다. 이 모듈은 CSS 전체에서 공유할 수 있는 일관되고 공통적인 박스 정렬 모델을 만들고자 합니다.

참고: 텍스트와 인라인 레벨 콘텐츠의 정렬은 [CSS-TEXT-3][CSS-INLINE-3]에서 정의됩니다.

참고: 이 명세는 여기 정의된 속성들이 초기값으로 설정될 때 CSS2.1에서 정의된 동작을 변경하려는 목적이 아닙니다. 구현자나 다른 사람이 불일치를 발견하면, CSSWG에 오류로 보고해 주시기 바랍니다.

위 섹션은 규범적인 내용이 아닙니다.

1.1. 모듈 상호작용

이 모듈은 [CSS2]9장10장에서 설명된 블록 레이아웃 모델에 새로운 정렬 기능을 추가하고, 과도하게 제약된 블록 레벨 박스 마진이 해결되는 방법을 재정의하며, vertical-align을 사용해 테이블 셀 콘텐츠 정렬과의 상호작용을 정의합니다. 관련 내용은 [CSS2] 17장에 있습니다.

이 속성들의 Grid Layout [CSS-GRID-1] 및 Flexible Box Layout [CSS-FLEXBOX-1]과의 상호작용은 각각의 모듈에서 정의되어 있습니다. 여기의 속성 정의는 [CSS-FLEXBOX-1](더 적고 이전의 허용값 집합)에서의 정의를 대체합니다.

이 모듈의 어떤 속성도 ::first-line 또는 ::first-letter 의사 요소에는 적용되지 않습니다.

1.2. 값 정의

이 명세는 CSS 속성 정의 규약[CSS2]에서 따르며, 값 정의 문법[CSS-VALUES-3]에서 사용합니다. 이 명세에서 정의되지 않은 값 타입은 CSS 값 및 단위 [CSS-VALUES-3]에서 정의됩니다. 다른 CSS 모듈과의 결합으로 이러한 값 타입의 정의가 확장될 수 있습니다.

속성별 정의에 명시된 값 외에도, 이 명세에서 정의된 모든 속성은 CSS-wide 키워드도 속성 값으로 사용할 수 있습니다. 가독성을 위해 명시적으로 반복하지 않았습니다.

1.3. 부분 구현

이 모듈의 기능 지원이 영향을 받는 다양한 레이아웃 모델에 따라 단계적으로 배포될 것으로 예상되므로, 부분 구현에 대한 규칙이 명확히 적용됩니다. 즉, 지원되지 않는 기능은 무효로 처리해야 하며, 해당 정렬 키워드가 적용되는 모든 레이아웃 모듈에서 지원되지 않는 경우에는 일반적으로 해당 속성을 지원하는 모델에서 무효로 처리해야 합니다.

예를 들어, 어떤 구현이 align-self[CSS-GRID-1][CSS-FLEXBOX-1]에서 지원한다면, start가 두 컨테이너(그리드와 플렉스) 모두에서 지원되지 않으면 무효로 처리해야 합니다. 하지만 같은 구현이 블록 레벨 요소에서는 align-self를 전혀 지원하지 않는 경우, align-self: start를 미구현해도 무효로 처리하는 요구 사항이 적용되지 않습니다.

2. 정렬 속성 개요

CSS의 박스 정렬 속성은 박스를 다른 박스 안에서 정렬하는 6개의 속성 집합입니다. 이 속성들은 두 가지 축으로 설명할 수 있습니다:

참고: 이 명세는 “justify”와 “align” 용어를 사용하여 메인/인라인과 교차/블록 차원에서의 정렬을 구분합니다. 완전히 임의적인 선택이지만, 두 용어를 사용함으로써 CSS의 모든 레이아웃 모델(CSS Flexbox 1 § 2 Flex Layout Box Model and Terminology 포함)에서 일관된 명명 체계를 쓸 수 있습니다.

다음 표는 박스 정렬 속성과 적용 가능한 display 타입을 요약합니다.

공통 정렬 대상 적용 대상
justify-content 메인/인라인 요소 내부의 콘텐츠 (실제로 padding 조정) 블록 컨테이너, 플렉스 컨테이너, 그리드 컨테이너
align-content 교차/블록
justify-self 인라인 부모 내 요소 (실제로 margin 조정) 블록 레벨 박스, 절대 위치 박스, 그리드 아이템
align-self 교차/블록 절대 위치 박스, 플렉스 아이템, 그리드 아이템
justify-items 인라인 박스 내부 아이템 (자식 아이템의 justify-self: auto 제어) 블록 컨테이너, 그리드 컨테이너
align-items 교차/블록 플렉스 컨테이너, 그리드 컨테이너

참고: *-items 속성은 해당 요소 자체에는 영향을 미치지 않습니다. 컨테이너에 설정하면, 자식 요소에 사용된 *-self: auto의 해석 방식을 지정합니다.

3. 정렬 용어

이 모듈이 CSS의 모든 레이아웃 모드에 대한 정렬 속성을 정의하므로, 몇 가지 추상적인 용어가 도입됩니다:

정렬 대상
정렬 대상은 해당 속성에 의해 정렬되는 것 또는 것들입니다. justify-selfalign-self의 경우, 정렬 대상은 속성이 설정된 박스의 마진 박스이며, 해당 박스의 쓰기 모드를 따릅니다. justify-contentalign-content의 경우, 정렬 대상은 레이아웃 모드에 따라 정의되며, 해당 콘텐츠의 일부를 의미합니다. 또한, 속성이 설정된 박스의 쓰기 모드를 따릅니다.
정렬 컨테이너
정렬 컨테이너정렬 대상이 그 안에서 정렬되는 사각형입니다. 이는 레이아웃 모드에 의해 정의되지만, 일반적으로 정렬 대상의 포함 블록이며, 해당 블록을 설정하는 박스의 쓰기 모드를 따릅니다.
대체 정렬
일부 정렬은 특정 상황에서만 충족될 수 있거나, 사용할 수 있는 공간이 제한됩니다. 예를 들어, space-between정렬 대상이 2개 이상일 때만 동작하며, 기준선 정렬이 충족된 후에는 남는 공간을 모두 흡수할 수 없을 수 있습니다. 이 경우 대체 정렬이 적용되어 (아래에 정의됨) 남는 공간을 완전히 소진합니다.

4. 정렬 키워드

모든 정렬 속성은 공통된 키워드 값 집합을 사용하며, 이 섹션에서 정의합니다. 키워드는 세 가지 범주로 나뉩니다:

위치 정렬
이 키워드는 정렬 컨테이너 내에서의 절대 위치로 정렬을 정의합니다.
기준선 정렬
이 키워드는 여러 정렬 대상의 기준선 사이의 관계로 정렬을 정의하며, 정렬 컨텍스트 내에서 적용됩니다.
분포 정렬
이 키워드는 정렬 대상 사이의 공간 분포로 정렬을 정의합니다.

4.1. 위치 정렬: center, start, end, self-start, self-end, flex-start, flex-end, left, right 키워드

위치 정렬 키워드는 정렬 대상을 그 정렬 컨테이너 기준에서 어디에 위치시킬지 지정합니다.

각 값의 의미는 다음과 같습니다:

center (self, content)
정렬 대상정렬 컨테이너 안에서 가운데에 맞춥니다.
start (self, content)
정렬 대상을 해당 축에서 정렬 컨테이너의 시작 가장자리에 맞춥니다.
end (self, content)
정렬 대상을 해당 축에서 정렬 컨테이너의 끝 가장자리에 맞춥니다.
self-start (self)
정렬 대상정렬 컨테이너의 해당 축에서 정렬 대상의 시작 방향에 맞춥니다.
self-end (self)
정렬 대상정렬 컨테이너의 해당 축에서 정렬 대상의 끝 방향에 맞춥니다.
flex-start (self, content)
플렉스 레이아웃에서만 사용됩니다. [CSS-FLEXBOX-1] 정렬 대상정렬 컨테이너플렉스 컨테이너의 main-start 또는 cross-start 방향에 맞춥니다.

플렉스 포맷팅 컨텍스트 밖에서 사용 시, 이 값은 start처럼 동작합니다. 즉, 플렉스 아이템이 아닌 박스(또는 플렉스 아이템처럼 동작하는 박스, 예를 들어 static position을 결정할 때 플렉스 컨테이너의 자식인 절대 위치 박스)에서는, self-alignment 속성에서 사용 시 start처럼 동작하며, 플렉스 컨테이너가 아닌 박스의 content-distribution 속성에서는 start처럼 동작합니다.

flex-end (self, content)
플렉스 레이아웃에서만 사용됩니다. 정렬 대상정렬 컨테이너플렉스 컨테이너의 main-end 또는 cross-end 방향에 맞춥니다.

플렉스 포맷팅 컨텍스트 밖에서 사용 시, 이 값은 end처럼 동작합니다. 즉, 플렉스 아이템이 아닌 박스(또는 플렉스 아이템처럼 동작하는 박스, 예를 들어 static position을 결정할 때 플렉스 컨테이너의 자식인 절대 위치 박스)에서는, self-alignment 속성에서 사용 시 end처럼 동작하며, 플렉스 컨테이너가 아닌 박스의 content-distribution 속성에서는 end처럼 동작합니다.

left (justify-*에만 사용)
정렬 대상정렬 컨테이너line-left 혹은 물리적 왼쪽 가장자리에 맞춥니다. 해당 축에서 적합한 방향을 사용합니다.

속성의 축이 좌↔우 축과 평행하지 않으면, 이 값은 start와 같이 동작합니다. 현재로서는 속성의 축이 좌↔우 축과 평행하지 않은 유일한 경우는 column 플렉스박스입니다.

right (justify-*에만 사용)
정렬 대상정렬 컨테이너line-right 혹은 물리적 오른쪽 가장자리에 맞춥니다. 해당 축에서 적합한 방향을 사용합니다.

속성의 축이 좌↔우 축과 평행하지 않으면, 이 값은 start와 같이 동작합니다. 현재로서는 속성의 축이 좌↔우 축과 평행하지 않은 유일한 경우는 column 플렉스박스입니다.

이 값들의 특정 부분집합을 나타내는 두 가지 문법 용어가 있습니다:

<self-position>
이 집합은 justify-selfalign-self에서 박스를 정렬 컨테이너 안에서 정렬할 때 사용되며, justify-items, align-items에서도 (justify-selfalign-self의 기본값 지정) 사용됩니다.
<self-position> = center | start | end | self-start | self-end |
        flex-start | flex-end
<content-position>
이 집합은 justify-contentalign-content에서 박스의 콘텐츠를 내부에서 정렬할 때 사용됩니다.
<content-position> = center | start | end | flex-start | flex-end

참고: leftright<self-position><content-position>에는 포함되지 않습니다. 위치 정렬 값으로 justify-content/justify-self/justify-items에서 유효하지만, align-* 속성에서는 허용되지 않습니다. 대신 justify-* 속성의 문법에 명시적으로 포함됩니다.

대부분의 레이아웃 모델(블록, 테이블, 그리드 등)에서, justify-* 속성은 항상 inline 축에서 정렬하고, align-* 속성은 항상 block 축에서 정렬합니다.

반면 flexbox는 justify-* 속성으로 main 축에서 정렬하고, align-* 속성으로 cross 축에서 정렬합니다. 이것은 flex-direction 값에 따라 다릅니다: flex-directionrow 또는 row-reverse일 때는 다른 레이아웃 모드와 일치합니다 (inline 축justify-*, block 축align-*); flex-directioncolumn 또는 column-reverse일 때는 반대 관계를 갖습니다.

"start"와 "end"의 이중 축 특성을 직교 플로우에서 더 이해하기 쉽게 설명 필요.

4.2. 기준선 정렬: baseline 키워드와 first / last 수식어

CSS Writing Modes 3 § 4.1 기준선 소개 참고.

기준선 정렬공유 정렬 컨텍스트(예: 한 행의 셀) 내에서 여러 정렬 대상정렬 기준선을 맞춰 위치시키는 위치 정렬의 한 형태입니다. 기준선 공유 그룹 내에서 정렬 대상의 위치가 기준선 정렬로 완전히 제약되지 않는 경우(즉, 기준선 정렬을 유지하면서 각각의 정렬 컨테이너 내에서 이동 가능할 때), 가능한 한 기준선 정렬을 유지하며 대체 정렬이 적용됩니다.

기준선 정렬 키워드는 <baseline-position> 문법 용어로 표현됩니다:

<baseline-position> = [ first | last ]? && baseline

firstlast 값은 박스에 기준선 정렬 선호도를 부여합니다: 각각 “first” 또는 “last”이며, 기본값은 “first”입니다.

각 값의 의미는 다음과 같습니다:

baseline
first baseline으로 계산되며, 아래에 정의되어 있습니다.
first baseline
first-baseline 정렬에 참여: 박스의 첫 번째 기준선 집합정렬 기준선을 해당 기준선 공유 그룹의 대응 기준선에 맞춥니다. 자세한 내용은 § 9.3 박스의 기준선 정렬을 참조하세요.

대체 정렬first baseline에 대해 safe self-start(self-alignment인 경우) 또는 safe start(content-distribution인 경우)입니다.

last baseline
last-baseline 정렬에 참여: 박스의 마지막 기준선 집합정렬 기준선을 해당 기준선 공유 그룹의 대응 기준선에 맞춥니다. 자세한 내용은 § 9.3 박스의 기준선 정렬을 참조하세요.

대체 정렬last baseline에 대해 safe self-end(self-alignment인 경우) 또는 safe end(content-distribution인 경우)입니다.

align-content에 지정된 경우, 이 값들은 기준선 콘텐츠 정렬을 유발하여 박스의 콘텐츠가 콘텐츠 박스 내에서 이동하게 하며, 박스 자체의 크기에 영향을 줄 수 있습니다. 자세한 내용은 § 5.4 기준선 콘텐츠 정렬을 참조하세요.

align-self / justify-self에 지정된 경우, 이 값들은 기준선 자기 정렬을 유발하여 박스 전체가 컨테이너 내에서 이동하게 하며, 컨테이너의 크기에 영향을 줄 수 있습니다. 자세한 내용은 § 6.4 기준선 자기 정렬을 참조하세요.

박스에 기준선 자기 정렬이 지정된 경우, 콘텐츠 분포가 먼저 수행되고, 그 결과 박스와 콘텐츠가 자기 정렬됩니다. 단, 박스가 동일 축에 기준선 콘텐츠 정렬을 가지고 있거나, 동일 축의 콘텐츠 분포 속성normal인 경우, 해당 축의 사용된 콘텐츠 분포 속성은 "first" 또는 "last" 기준선 자기 정렬 선호도에 따라 각각 start 또는 safe end가 됩니다.

예시 이미지를 추가하세요.

박스가 공유 정렬 컨텍스트에 속하지 않으면, 대체 정렬이 사용됩니다. 예를 들어 align-content: baseline이 블록 박스에 지정되면, start 정렬로 대체됩니다. 대체 정렬기준선 공유 그룹정렬 컨테이너 내에서 정렬될 때에도 사용됩니다.

참고: 두 키워드는 동일하며, baseline이 더 짧으므로, CSSOM은 first baselinebaseline으로 직렬화합니다. CSSOM § 6.7.2 CSS 값 직렬화 참고.

참고: 관련성이 약간 있는 vertical-align 속성의 경우, CSS2.1의 설계 결정 불일치로 인해 baselinefirst baseline과 동일하지 않습니다. 인라인 레벨 박스의 기준선 정렬 선호도display에 따라 달라집니다. (예: inline-block은 기본적으로 마지막 기준선을 사용하고, inline-table은 기본적으로 첫 번째 기준선을 사용합니다.)

4.3. 분포 정렬: stretch, space-between, space-around, space-evenly 키워드

분포 정렬 값은 justify-contentalign-content에서 컨테이너의 추가 공간을 정렬 대상 사이에 분산시킬 때 사용됩니다.

space-between | space-around | space-evenly | stretch
분포 정렬

공간을 이 방식으로 분산할 수 없는 경우, 해당 값은 대체 정렬처럼 동작합니다. 각 분포 값에는 기본 대체 정렬이 있습니다. (향후 모듈에서는 대체 정렬을 명시적으로 지정할 수 있게 할 수 있습니다.)

space-between
정렬 대상들을 정렬 컨테이너 내에서 균등하게 분포시킵니다. 첫 번째 정렬 대상정렬 컨테이너의 시작 가장자리에, 마지막 정렬 대상은 끝 가장자리에 배치되고, 나머지 정렬 대상은 인접한 정렬 대상 간의 간격이 동일하도록 분포됩니다.
예: 세 개의 아이템이 있을 때, 모든 여분의 공간을 둘로 나눠서 분배: 첫 번째 두 아이템 사이와 마지막 두 아이템 사이에 각각 절반씩.

이 값의 기본 대체 정렬safe flex-start입니다. (플렉스 레이아웃이 아닌 경우 flex-startstart와 동일합니다.)

space-around
정렬 대상들을 정렬 컨테이너 내에서 균등하게 분포시키며, 양 끝에는 절반 크기의 공간이 추가됩니다. 정렬 대상은 인접한 정렬 대상 간의 간격이 동일하며, 첫 번째와 마지막 정렬 대상 전후 간격은 나머지 간격의 절반입니다.
예: 세 개의 아이템이 있을 때, 모든 여분의 공간을 6등분하여 분배: 시작 부분에 1/6, 끝 부분에 1/6, 첫 두 아이템과 마지막 두 아이템 사이에 각각 2/6(1/3)씩.

이 값의 기본 대체 정렬safe center입니다.

space-evenly
정렬 대상들을 정렬 컨테이너 내에서 균등하게 분포시키며, 양 끝에는 완전한 크기의 공간이 추가됩니다. 정렬 대상은 인접한 정렬 대상 간, 첫 번째 정렬 대상 전, 마지막 정렬 대상 후의 간격이 모두 동일하게 분포됩니다.
예: 세 개의 아이템이 있을 때, 모든 여분의 공간을 4등분하여 분배: 시작, 끝, 첫 두 아이템 사이, 마지막 두 아이템 사이에 각각 1/4씩.

이 값의 기본 대체 정렬safe center입니다.

stretch
정렬 대상의 전체 크기가 정렬 컨테이너보다 작으면, auto 크기의 정렬 대상의 크기가 동일하게(비례적 아님) 증가하며, max-height/max-width(또는 동등 기능)의 제약을 존중하면서 전체 크기가 정렬 컨테이너를 정확히 채우도록 합니다.
예: 세 개의 아이템이 있을 때, 모든 여분의 공간을 3등분하여 각 아이템에 1/3씩 분배.

이 값의 기본 대체 정렬flex-start입니다. (플렉스 레이아웃이 아닌 경우 flex-startstart와 동일합니다.)

참고: 이 `align-content/stretch` 정의는 content-distribution 속성에 적용됩니다; self-alignment 속성 justify-self/align-self에는 별도의 stretch 값이 있으며, 이 값은 정렬 대상정렬 컨테이너에 정확히 맞추도록 확장 또는 축소할 수 있습니다.

이 값들은 <content-distribution> 문법 용어로 표현됩니다:

<content-distribution> = space-between | space-around | space-evenly | stretch

4.4. 오버플로우 정렬: safeunsafe 키워드와 스크롤 안전 한계

일부 상황에서는, 지정된 정렬대로 맞추면 정렬 주체정렬 컨테이너를 넘치게 되어, 데이터 손실을 초래할 수 있습니다. 예를 들어, 사이드바의 내용이 무조건 가운데 정렬될 경우, 너무 큰 항목이 사이드바를 넘치면 뷰포트의 시작(왼쪽) 끝을 넘어 표시될 수 있고, 이쪽은 스크롤로 접근할 수 없습니다.

아래 그림은 “안전” 가운데 정렬과 “비안전” 가운데 정렬의 차이를 컬럼 flexbox를 예시로 들어 보여줍니다:
About
Authoritarianism
Blog
About
Authoritarianism
Blog
가운데 정렬된 항목이 컨테이너보다 클 때 왼쪽은 "안전", 오른쪽은 "비안전" 가운데 정렬 예시입니다.

왼쪽 그림의 항목들은 넘치지 않는 한 가운데 정렬되며, 넘치면 모든 오버플로우가 끝쪽으로 나가게 됩니다. 반면 오른쪽 그림의 항목은 모두 엄격하게 가운데 정렬되어, 너무 긴 항목은 양쪽 모두 넘치게 됩니다.

만약 컨테이너가 페이지의 왼쪽 끝에 배치되어 있다면, “안전” 정렬이 더 바람직할 수 있습니다. 긴 항목 전체를 읽을 수 있기 때문이며, 화면 왼쪽에서 잘리지 않습니다. 상황에 따라, “비안전” 정렬이 더 나을 수도 있습니다. 모든 항목이 정확히 가운데로 정렬되기 때문입니다.

이 상황을 제어하기 위해, 오버플로우 정렬 모드를 명확히 설정할 수 있습니다. “비안전” 정렬은 오버플로우 상황에서도 지정된 정렬 모드를 그대로 적용하며, 데이터 손실이 발생할 수 있습니다. 반면 “안전” 정렬은 오버플로우 상황에서 데이터 손실을 피하기 위해 정렬 모드를 변경합니다. 기본 동작은 정렬 주체를 스크롤 영역 내에 포함시키는 것이지만, 작성 시점에는 이 안전 기능이 아직 구현되어 있지 않습니다.

<overflow-position> = unsafe | safe
safe
정렬 주체의 크기가 정렬 컨테이너를 넘치면, 정렬 주체를 정렬 모드가 flex-start인 것처럼 정렬합니다.
unsafe
정렬 주체정렬 컨테이너의 상대적인 크기에 관계없이, 지정된 정렬 값을 그대로 적용합니다.
(값 지정 없음)
오버플로우 정렬이 명시적으로 지정되지 않은 경우, 기본 오버플로우 정렬은 “안전”과 “비안전”의 혼합입니다. 자세한 내용은 § 4.4.1 자동 오버플로우 정렬 안전을 참고하세요.

4.4.1. 자동 오버플로우 정렬 안전성

속성에 오버플로우 정렬 모드가 지정되지 않은 경우, 기본 동작은 safeunsafe 사이에 있으며, 레이아웃 모드에 따라 달라집니다.

4.4.1.1. 스크롤 컨테이너의 콘텐츠 분포

콘텐츠 분포에서 스크롤 컨테이너에 대한 기본 오버플로우 정렬 동작은 unsafe입니다. normal이 아닌 content-distribution 속성 값은 오버플로우된 콘텐츠에 접근할 수 있도록 스크롤 가능한 오버플로우 영역을 변경합니다. 자세한 내용은 § 5.3 정렬 오버플로우 및 스크롤 컨테이너 참고.

4.4.1.2. 절대 위치 박스의 자기 정렬

절대 위치(absolute positioning)가 적용된 정렬 주체에서 관련 사용된 자기-정렬 속성(self-alignment property)normal이 아닐 때, 기본 오버플로우 정렬 동작은 다음과 같습니다:

  1. 정렬 주체inset-수정된 컨테이닝 블록 내에 들어갈 경우, 넘치지 않는 선에서 지정된 대로 정렬합니다.

  2. 그렇지 않고, 정렬 주체오버플로우 제한 사각형(overflow limit rect) 내에는 들어갈 경우, 정렬 주체inset-수정된 컨테이닝 블록을 완전히 덮도록 정렬하되, 넘치지 않는 선에서 지정된 대로 최대한 정렬합니다.

  3. 그 외의 경우, 정렬 주체오버플로우 제한 사각형 내에서 시작점 정렬(start-align)합니다 (이는 safe와 유사합니다).

여기서 오버플로우 제한 사각형정렬 주체inset-수정된 컨테이닝 블록원래 컨테이닝 블록(original containing block)의 바운딩 사각형입니다. 하지만 스크롤 가능한 오버플로우 영역을 갖는 스크롤 컨테이너에서는, 오버플로우된 절대 위치 박스의 가시성을 보장하기 위해 원래 컨테이닝 블록스크롤 컨테이너에 의해 생성되는 경우(그리고 fixed containing block이 아닌 경우), 오버플로우 제한 사각형도달 불가 스크롤 오버플로우 영역으로 뻗지 않는 방향에 대해서는 무한대로 확장됩니다.

(위 조건을 만족하지 못하는 절대 위치 정렬 주체의 경우, § 4.4.1.3 기타 모든 정렬을 참고하세요.)

참고: 이 규칙들은 박스의 위치를 제한하여 오버플로우를 최소화하며, 가능하면 지정된 정렬 값을 따르면서, 박스의 크기가 변해도 연속적인 동작을 보장합니다.

4.4.1.3. 기타 정렬

그 외 모든 요소의 경우:

그 밖의 모든 요소에 대해:

  1. 정렬 주체정렬 컨테이너를 넘치면, 지정된 대로 정렬합니다 (unsafe).

  2. 정렬 주체가 가장 가까운 상위 스크롤 컨테이너스크롤 가능한 오버플로우 영역을 넘치게 되는 경우 (즉, "스크롤 불가" 영역으로 확장되는 경우), 그 방향의 오버플로우는 남은 오버플로우를 반대편으로 치우치게 하여 제한합니다.

“스마트” 기본 동작을 구현하는 것이 웹 호환성이 떨어질 수 있습니다 (하지만 우리는 그렇지 않기를 희망하며 실제로 가능할 것으로 믿습니다). 그러므로 UA는 이 부분에 대한 모든 피드백을 WG에 전달해야 합니다. “스마트” 기본 동작을 구현하지 않은 UA는 align-content 속성이 블록 컨테이너일 때는 safe로, 그 외의 경우에는 unsafe로 동작해야 합니다.

5. 콘텐츠 분포: 박스 내부 콘텐츠의 정렬

콘텐츠 분포는 박스의 콘텐츠가 콘텐츠 박스 내부에서 어떻게 정렬되는지 제어합니다. content-distribution 속성 align-contentjustify-content(그리고 place-content 축약형)으로 지정합니다.

요소 내부 콘텐츠의 정렬이 영향을 받는 다이어그램.

5.1. justify-contentalign-content 속성

이름: align-content
값: normal | <baseline-position> | <content-distribution> | <overflow-position>? <content-position>
초기값: normal
적용 대상: 블록 컨테이너, 다단 컨테이너, 플렉스 컨테이너, 그리드 컨테이너
상속: 아니오
백분율: 해당 없음
계산값: 지정된 키워드
정규 순서: 문법에 따라
애니메이션 타입: 불연속적
이름: justify-content
값: normal | <content-distribution> | <overflow-position>? [ <content-position> | left | right ]
초기값: normal
적용 대상: 다단 컨테이너, 플렉스 컨테이너, 그리드 컨테이너
상속: 아니오
백분율: 해당 없음
계산값: 지정된 키워드
정규 순서: 문법에 따라
애니메이션 타입: 불연속적

박스 콘텐츠 전체(정렬 대상)를 박스 자체(정렬 컨테이너) 내에서 정렬합니다: justify-content는 박스의 인라인/행/main 축, align-content는 블록/열/cross 축에 따라 정렬합니다. normal 외의 값은 위 § 4 정렬 키워드에서 정의됩니다.

모든 레이아웃 모드에서, 정렬 대상정렬 컨테이너 모두 *-content 속성이 설정된 박스의 쓰기 모드를 따릅니다.

5.1.1. 블록 컨테이너(테이블 셀 포함)

정렬 컨테이너 블록 컨테이너의 콘텐츠 박스.
정렬 대상 블록의 전체 콘텐츠(단위로서).
align-content block 축. <content-distribution>이 지정된 경우, 해당 대체 정렬이 대신 사용됨. <overflow-position>이 지정되지 않고, 블록 컨테이너스크롤 컨테이너가 아니면, 정렬은 safe임.
justify-content 블록 컨테이너에는 적용되지 않으며 효과 없음.
normal 동작 normal 외의 모든 값은 블록 컨테이너가 독립적인 포맷팅 컨텍스트를 생성하도록 강제함.

테이블 셀의 경우, align-content: normal의 동작은 vertical-align의 계산값에 따라 결정됨: topstart처럼, bottomend처럼 동작; middlecenter처럼, 그 외 값은 baseline처럼 동작. [CSS2]

그 외에는 start처럼 동작합니다.

5.1.2. 다단 컨테이너

정렬 컨테이너 다단 컨테이너의 콘텐츠 박스.
정렬 대상 컬럼 박스, 컬럼 박스 사이에 삽입된 간격도 관련 컬럼 갭에 더해짐.
align-content block 축, 컬럼 박스(및 컬럼을 span하는 요소) 전체를 하나의 단위로 취급. <content-distribution>이 지정된 경우, 해당 대체 정렬이 대신 사용됨.
justify-content inline 축.
normal 동작 normalstretch처럼 동작; 둘 다 [CSS-MULTICOL-1]의 컬럼 크기 규칙에서 설명된 대로 정의됨.

auto가 아닌 column-width를 가진 다단 컨테이너의 경우, justify-content 값이 normal 또는 stretch가 아니면, 컬럼들이 지정한 column-width를 가지며 컨테이너를 채우기 위해 늘어나지 않음. 그 후 컬럼 박스는 justify-content에 따라 정렬됨.

5.1.3. 플렉스 컨테이너

정렬 컨테이너 flex 컨테이너의 콘텐츠 박스(content box).
정렬 주체 justify-content의 경우, 각 플렉스 라인플렉스 아이템들.

align-content의 경우, 플렉스 라인 자체. 단, 이 속성은 다줄 플렉스 컨테이너에서만 효과가 있습니다.

align-content 교차 축(cross axis).
justify-content justify-content 속성은 메인 축(main axis)에서 적용됨. 다만 메인 축에서의 스트레칭은 flex가 제어하므로, stretchflex-start처럼 동작합니다.
normal 동작 normalstretch처럼 동작합니다.

자세한 내용은 [CSS-FLEXBOX-1] 참고.

5.1.4. 그리드 컨테이너

정렬 컨테이너 그리드 컨테이너의 콘텐츠 박스.
정렬 대상 해당 축의 그리드 트랙, 트랙 사이에 삽입된 간격은 거터에 추가, 겹친 거터는 공간 삽입의 한 기회로 취급.
align-content block 축, 그리드 행 정렬.
justify-content inline 축, 그리드 열 정렬.
normal 동작 normalstretch처럼 동작.

자세한 내용은 [CSS-GRID-1] 참고.

5.2. 콘텐츠 분포 축약형: place-content 속성

이름: place-content
값: <'align-content'> <'justify-content'>?
초기값: normal
적용 대상: 각 속성별로 참조
상속: 아니오
백분율: 해당 없음
계산값: 각 속성별 참조
정규 순서: 문법에 따라
애니메이션 타입: 불연속적

축약형 속성align-contentjustify-content를 한 번에 설정합니다. 첫 번째 값은 align-content에 할당됨. 두 번째 값은 justify-content에 할당됨; 생략 시 첫 번째 값을 복사함, 단 그 값이 <baseline-position>이면 기본값은 start임.

5.3. 정렬 오버플로우 및 스크롤 컨테이너

콘텐츠 분배 속성이 오버플로우된 정렬 주체를 가진 스크롤 컨테이너에 설정되면, 도달 불가 스크롤 오버플로우 영역의 클리핑을 정렬 주체가 자신의 start 정렬 위치로 스크롤될 수 있을 만큼만 줄입니다.

예를 들어, 스크롤 가능한 플렉스 컨테이너가 justify-content: flex-end (또는 justify-content: flex-startflex-flow: row-reverse가 함께 지정된 경우)라면, 해당 레이아웃 흐름 내(in-flow) 콘텐츠는 플렉스 컨테이너의 메인-엔드(main-end) 엣지에 콘텐츠의 메인-엔드 엣지가 맞추어져 초기 배치됩니다. 그리고 콘텐츠가 플렉스 컨테이너의 메인-스타트(main-start) 엣지를 넘치게 보입니다. 하지만 뷰어(사용자)는 위쪽으로 스크롤하여 넘치는 레이아웃 흐름 내 콘텐츠를 볼 수 있는데, 이는 justify-content: flex-start가 지정된 것과 같은 동작입니다.
이 이미지는 적절한 SVG로 교체 필요.

참고: 정렬 주체스크롤 가능한 오버플로우 영역과 반드시 동일하지 않습니다: 정렬 주체를 넘쳐 흐르는 콘텐츠(예: 흐름 밖(out-of-flow) 박스)는 스크롤 가능한 오버플로우 영역은 키우지만, 정렬 주체는 키우지 않습니다. 따라서 end로 정렬된 스크롤 컨테이너라도 초기에 완전히 아래까지 스크롤되지 않을 수 있고, 배치된 콘텐츠가 더 안쪽 도달 불가 스크롤 오버플로우 영역에 위치한다면 레이아웃 흐름 내(in-flow) 콘텐츠로 정렬 주체가 만들어질 때라도 클리핑될 수 있습니다.

오버플로우는 정렬 주체의 일부가 아닙니다, 스크롤 컨테이너일 때도 마찬가지입니다.

이 이미지도 교체하세요.

참고: 스크롤바의 존재는 스크롤 컨테이너콘텐츠 박스(content box)의 크기를, 따라서 정렬 컨테이너 및/또는 정렬 주체의 크기를 변경시킬 수 있습니다.

5.4. 기준선 콘텐츠 정렬

행과 유사한 레이아웃 컨텍스트(공유 정렬 컨텍스트)에 참여하는 박스의 콘텐츠는 서로 기준선 정렬될 수 있습니다. 기준선 콘텐츠 정렬은 박스의 패딩을 효과적으로 늘려 해당 콘텐츠의 정렬 기준선을 동일 기준선 공유 그룹 내 다른 박스의 기준선과 맞춥니다.

기준선 콘텐츠 정렬align-content 축이 박스의 block 축과 평행할 때만 적용됩니다 (즉, "column" 플렉스 컨테이너에는 적용되지 않음); 그렇지 않으면 대체 정렬이 사용됩니다.

기준선 콘텐츠 정렬에 참여하는 박스 집합은 레이아웃 모델에 따라 다릅니다:

테이블 셀:
(대체되지 않은) 테이블 셀은 인라인 축이 테이블과 평행하고, 계산된 align-contentfirst baseline(last baseline)일 때, 행의 시작/끝에서 기준선 콘텐츠 정렬에 참여합니다.

참고: 동일 컬럼을 공유하는 셀의 기준선 콘텐츠 정렬은 지원되지 않습니다; 하지만 수요와 구현자 관심이 충분하다면 향후 버전에서 추가될 수 있습니다.

플렉스 아이템:
대체되지 않은 플렉스 아이템은 인라인 축이 main 축과 평행하고, 계산된 align-contentfirst baseline/last baseline일 때, 플렉스 라인에서 기준선 콘텐츠 정렬에 참여합니다.
그리드 아이템:
대체되지 않은 그리드 아이템은 인라인 축과 평행한 행 또는 열의 시작/끝에서, 계산된 align-contentfirst baseline/last baseline일 때 기준선 콘텐츠 정렬에 참여합니다.

추가적으로, 기준선 콘텐츠 정렬에 참여하려면 조정된 자기 정렬 선호도도 있어야 하며, 해당 박스가 기준선 공유 그룹의 다른 박스와 같은 방향의 가장자리가 맞춰지도록 보장해야 합니다. 즉, 박스의 start(end) 마진 가장자리박스의 가장자리와 실제로 맞춰지도록 해야 하며, 포함 블록 내에서 기준선 정렬 선호도가 "first"("last")일 때 적용됨. 그렇지 않으면 대체 정렬이 적용됩니다.

자기 정렬 선호도가 언제 조정되는가?

박스의 start 마진 가장자리포함 블록의 해당 가장자리와 맞춰지고, "first" 기준선 정렬 선호도에 대해 조정된 자기 정렬 선호도가 있는 경우, 해당 축에서:

박스의 end 마진 가장자리포함 블록의 해당 가장자리와 맞춰지고, "last" 기준선 정렬 선호도에 대해 조정된 자기 정렬 선호도가 있는 경우, 해당 축에서:

추가 자세한 내용은 § 9.3 박스의 기준선 정렬을 참고. 기준선 콘텐츠 정렬은 박스의 고유 크기를 늘릴 수 있습니다.

6. 자기 정렬: 박스를 부모 내에서 정렬

자기 정렬은 박스가 포함 블록 내에서 어떻게 정렬되는지 제어합니다. self-alignment 속성 align-self, justify-self(그리고 place-self 축약형)으로 지정합니다.

요소가 포함 블록 내에서 정렬되는 다이어그램.

6.1. 인라인 축(또는 메인 축) 자기 정렬: justify-self 속성

이름: justify-self
값: auto | <overflow-position>? [ normal | <self-position> | left | right ]
| stretch | <baseline-position>
초기값: auto
적용 대상: 블록 레벨 박스, 절대 위치 박스, 그리드 항목
상속: 아니오
백분율: 해당 없음
계산된 값: 명시된 키워드들
정식 순서: 문법에 따름
애니메이션 타입: 불연속(discrete)

박스(즉, 정렬 주체)를 자신의 컨테이닝 블록(즉, 정렬 컨테이너) 내에서 정렬 컨테이너의 인라인/row/main 축을 따라 맞춥니다: 박스의 바깥쪽 에지가 정렬 컨테이너 내에서 설명된 정렬 값에 따라 맞춰집니다. 값은 다음과 같은 의미를 갖습니다:

auto

박스에 부모가 없거나, 절대 위치 박스의 실제 위치를 결정할 때 normal처럼 동작합니다. 그 외의 경우 또는 절대 위치 박스의 static 위치를 결정할 때는 부모 박스의 계산된 justify-items 값 (legacy 키워드 제외)을 따릅니다.

normal

레이아웃 모드에 대한 “기본” 정렬을 나타냅니다. 아래 설명대로 동작 방식은 레이아웃 모드에 따라 달라집니다.

<self-position> | left | right

박스의 위치를 지정한 대로 이동시킵니다, § 4 정렬 키워드 참고.

<overflow-position>

박스가 오버플로우될 때 정렬 방식을 제어합니다, § 4.4 오버플로우 정렬: safe와 unsafe 키워드 및 스크롤 안전 한계 참고.

stretch

박스의 계산된 width/height (축에 따라 해당하는 값) 이 auto이고, 양쪽 마진(축에 따라 해당)이 auto가 아니라면, 박스의 사용된 크기를 정렬 컨테이너를 최대한 채우도록 필요한 길이로 설정하지만, min-height/min-width/max-height/max-width의 제한은 지킵니다.

별도 지정이 없는 한, 이 값은 일반적으로 flex-start로 대체되며, 박스가 first baseline 또는 last baseline baseline content-alignment이 동일 축에 지정된 경우에는 각각 self-start 또는 self-end로 대체됩니다.

참고: stretch 키워드는 요소를 컨테이너에 맞게 줄일 수도 있습니다.

<baseline-position>

베이스라인 자기-정렬을 의미하며, § 4.2 베이스라인 정렬: baseline 키워드와 first/last 모디파이어, § 6.4 베이스라인 자기-정렬, § 9 베이스라인 정렬 상세에 정의되어 있습니다.

stretch 이외의 값은 width/heightauto일 때 fit-content로 처리합니다.

참고: auto 마진은 마진 영역의 크기를 효과적으로 조정하므로 justify-self보다 우선됩니다.

6.1.1. 블록 레벨 박스

justify-self 일반적으로 블록의 컨테이닝 블록인라인 축입니다. 정적 위치(static-position) 컨테이닝 블록인라인 축을 사용합니다 정적 위치를 결정할 때.
Alignment Container 박스의 컨테이닝 블록입니다, 단, 블록 포맷팅 컨텍스트를 생성하고 플로트 옆에 배치된 블록 레벨 요소의 경우에는, 정렬 컨테이너가 플로트가 차지하는 공간만큼 줄어듭니다, 컨테이닝 블록쓰기 모드를 가정합니다.
Alignment Subject 블록의 마진 박스이며, 블록의 쓰기 모드를 가정합니다.
normal 동작 박스는 블록 레이아웃의 기본 규칙에 따라 배치됩니다 (CSS2.1§10.3 참고).
기타 세부사항 자동 크기블록 레벨 박스에서 justify-selfnormal이 아닐 때 fit-content와 동일합니다 (예: stretch가 아니라, 이는 비치환(non-replaced) 블록 레벨 박스에서 일반적입니다). 또한, CSS2.1 블록 레벨 포매팅 [CSS2]의 관점에서, 10.3.3절의 “과도 제약(over-constrained)” 계산 규칙은 여기에서 지정한 정렬을 우선하기 위해 무시되며, 따라서 마진 속성의 사용 값은 과도 제약을 보정하기 위해 조정되지 않습니다.

이 속성은 플로트에는 적용되지 않습니다.

익명 블록 박스는 항상 normal처럼 동작합니다.

이 규칙의 효과는, 예를 들어 자동 크기 블록 레벨 테이블이 옆 마진을 유지한 채 정렬될 수 있다는 것입니다. 테이블의 최대 콘텐츠 크기가 컨테이닝 블록보다 더 좁다면, 그 크기로 수축 래핑되어 지정한 대로 정렬됩니다. 테이블의 최대 콘텐츠 크기가 더 넓다면 컨테이닝 블록을 채우고, 마진이 컨테이닝 블록 가장자리로부터 적절한 간격을 제공합니다.

6.1.2. 절대 위치 박스

이 섹션은 justify-self가 절대 위치 박스의 마진 박스가 (절대 배치) 컨테이닝 블록에 대해 어떻게 배치되는지에 미치는 영향을 설명합니다.

justify-self 블록의 컨테이닝 블록의 인라인 축입니다.
정렬 컨테이너 박스의 컨테이닝 블록이며, inset 속성(top/right/bottom/left)의 영향이 반영됩니다, 컨테이닝 블록쓰기 모드를 가정합니다. 관련 축의 inset 속성 둘 다 auto일 경우, 박스의 정적 위치 사각형(static-position rectangle)을 사용합니다 (즉, 두 inset을 박스의 정적 위치로 설정), 정적 위치 컨테이닝 블록쓰기 모드를 가정합니다.
정렬 주체 박스의 마진 박스, 박스의 쓰기 모드를 가정합니다.
normal 동작 박스 유형에 따라 stretch 또는 start처럼 동작합니다. CSS Positioned Layout 3 § 4 절대 위치 레이아웃 모델 참고.
기타 세부사항 CSS2.1 포맷팅 [CSS2]의 관점에서, 10.3.7절의 “과도 제약(over-constrained)” 계산 규칙은 여기서 지정한 정렬을 우선하여 무시되며, inset 속성의 사용 값도 과도 제약을 보정하기 위해 조정되지 않습니다.

stretch 또는 normal이 아닌 값은 치환되지 않은 절대 위치 박스(non-replaced absolutely-positioned boxes)에서 해당 축의 fit-content 크기 계산 방식을 사용하여 auto 크기를 결정합니다.

stretch는 치환된 절대 위치 박스(replaced absolutely-positioned boxes)도 치환되지 않은 박스처럼 컨테이닝 블록을 채우도록 만듭니다.

참고: 한쪽만 inset 속성이 auto이면, CSS2 10.3.7절의 계산 방식이 크기 및 위치를 완전히 결정하며, justify-self는 효과가 없습니다. (둘 다 auto이면, 박스는 정적 위치로 배치되며, 위 설명처럼 정적 위치 사각형 안에서 정렬할 수 있습니다.)

6.1.3. 테이블 셀

이 속성은 테이블 셀에 적용되지 않습니다. 테이블 레이아웃에 의해 위치와 크기가 완전히 제약되기 때문입니다.

6.1.4. 플렉스 아이템

이 속성은 플렉스 아이템에는 적용되지 않습니다. 메인 축에 여러 아이템이 있기 때문입니다. 늘어남은 flex, 메인 축 정렬은 justify-content 참고. [CSS-FLEXBOX-1]

6.1.5. 그리드 아이템

justify-self 그리드의 인라인 축입니다.
정렬 컨테이너 그리드 아이템그리드 영역이며, 그리드 컨테이너쓰기 모드를 가정합니다.
정렬 주체 그리드 아이템의 마진 박스이며, 그리드 아이템쓰기 모드를 가정합니다.
normal 동작 stretch(일반적인 비치환 요소) 또는 start(일반적인 치환 요소)로 크기가 정해집니다; Grid Item Sizing ([CSS-GRID-1]) 참고. 이후 결과 박스는 시작점 정렬(start-aligned)됩니다.

[CSS-GRID-1]에서 자세한 내용 참고.

6.2. 블록 축(또는 교차 축) 자기 정렬: align-self 속성

이름: align-self
값: auto | <overflow-position>? [ normal | <self-position> ]
| stretch | <baseline-position>
초기값: auto
적용 대상: 플렉스 아이템, 그리드 아이템, 절대 위치 박스
상속: 아니오
백분율: 해당 없음
계산된 값: 명시된 키워드들
정식 순서: 문법에 따름
애니메이션 타입: 불연속(discrete)

박스(즉, 정렬 주체)를 자신의 컨테이닝 블록(즉, 정렬 컨테이너) 내에서 정렬 컨테이너의 블록/열/교차(cross) 축을 따라 맞춥니다: 박스의 바깥쪽 에지가 정렬 컨테이너 내에서 설명된 정렬 값에 따라 맞춰집니다. 값은 다음과 같은 의미를 갖습니다:

auto

박스에 부모가 없거나, 절대 위치 박스의 실제 위치를 결정할 때 normal처럼 동작합니다. 그 외의 경우 또는 절대 위치 박스의 static 위치를 결정할 때는 부모 박스의 계산된 align-items 값 (legacy 키워드 제외)을 따릅니다.

normal

레이아웃 모드에 대한 “기본” 정렬을 나타냅니다. 아래에서 정의되어 있습니다.

<self-position>

박스의 위치를 지정한 대로 이동시킵니다, § 4 정렬 키워드 참고.

<overflow-position>

박스가 오버플로우될 때 정렬 방식을 제어합니다, § 4.4 오버플로우 정렬: safe와 unsafe 키워드 및 스크롤 안전 한계 참고.

stretch

justify-self에 대해 § 6.1 인라인 축(또는 메인 축) 자기-정렬: justify-self 속성에서 정의된 것과 같습니다.

<baseline-position>

베이스라인 자기-정렬을 의미하며, § 4.2 베이스라인 정렬: baseline 키워드와 first/last 모디파이어, § 6.4 베이스라인 자기-정렬, § 9 베이스라인 정렬 상세에 정의되어 있습니다.

참고: auto 마진은 마진 영역의 크기를 효과적으로 조정하므로 align-self보다 우선됩니다.

6.2.1. 블록 레벨 박스

align-self 속성은 블록 레벨 박스(플로트 포함)에는 적용되지 않습니다. block 축에 여러 아이템이 있기 때문입니다.

6.2.2. 절대 위치 박스

이 섹션은 align-self가 절대 위치 박스의 마진 박스가 (절대 위치) 포함 블록 기준으로 어떻게 배치되는지에 미치는 영향을 설명합니다.

align-self 박스의 포함 블록block 축, 일반적으로. static-position 포함 블록block 축static position을 결정할 때 사용.
정렬 컨테이너 박스의 포함 블록, inset 속성(top/right/bottom/left)에 의해 수정됨, 포함 블록쓰기 모드를 따름. 해당 축의 두 inset 속성이 모두 auto인 경우, 박스의 static-position 사각형 사용(두 inset 모두 박스의 static position으로 설정) 쓰기 모드static-position 포함 블록을 따름.
정렬 대상 박스의 마진 박스, 박스의 쓰기 모드를 따름.
normal 동작 박스 유형에 따라 stretch 또는 start처럼 동작. 자세한 내용은 CSS Positioned Layout 3 § 4 절대 위치 레이아웃 모델 참고.
기타 세부사항 CSS2.1 포맷팅 관점에서 [CSS2] 10.6.4절의 "과도 제약(over-constrained)" 계산 규칙은 여기 지정된 정렬을 우선하기 위해 무시되며, inset 속성의 사용 값도 과도 제약 보정을 위해 조정되지 않습니다.

stretch 또는 normal이 아닌 값은 치환되지 않은 절대 위치 박스(non-replaced absolutely-positioned boxes)에서 해당 축의 fit-content 크기 계산을 사용하여 auto 크기를 결정합니다.

stretch는 치환된 절대 위치 박스(replaced absolutely-positioned boxes)도 치환되지 않은 박스처럼 컨테이닝 블록을 채우게 만듭니다.

참고: 한쪽만 inset 속성이 auto이면, CSS2 10.6.4절의 계산이 크기와 위치를 완전히 결정하며, align-self는 효과가 없습니다. (둘 다 auto이면, 박스는 정적 위치로 배치되며, 위 설명 참조, 정적 위치 사각형 안에서 정렬 가능합니다.)

6.2.3. 테이블 셀

이 속성은 테이블 셀에 적용되지 않습니다. 테이블 레이아웃에 의해 위치와 크기가 완전히 제약되기 때문입니다.

6.2.4. 플렉스 아이템

align-self 플렉스 컨테이너교차 축.
정렬 컨테이너 플렉스 라인, 플렉스 아이템이 속한 라인, 쓰기 모드플렉스 컨테이너를 따름.
정렬 대상 플렉스 아이템의 마진 박스, 쓰기 모드플렉스 아이템을 따름.
normal 동작 stretch처럼 동작.

자세한 내용은 [CSS-FLEXBOX-1] 참고.

6.2.5. 그리드 아이템

align-self 그리드의 block 축.
정렬 컨테이너 그리드 아이템그리드 영역, 쓰기 모드그리드 컨테이너를 따름.
정렬 대상 그리드 아이템의 마진 박스, 쓰기 모드그리드 아이템을 따름.
normal 동작 stretch(일반적인 비치환 요소) 또는 start(일반적인 치환 요소)로 크기가 정해집니다; Grid Item Sizing( [CSS-GRID-1] 참고). 이렇게 만들어진 박스는 시작점 정렬(start-aligned)됩니다.

자세한 내용은 [CSS-GRID-1] 참고.

6.3. 자기 정렬 축약형: place-self 속성

이름: place-self
값: <'align-self'> <'justify-self'>?
초기값: auto
적용 대상: 각 속성별로 참조
상속: 아니오
백분율: 해당 없음
계산된 값: 각 속성별로 참조
정식 순서: 문법에 따름
애니메이션 타입: 불연속(discrete)

약식 속성align-selfjustify-self 속성을 한 번에 선언합니다. 첫 번째 값은 align-self에 할당되고, 두 번째 값은 justify-self에 할당됩니다; 생략 시에는 첫 번째 값을 복사하여 사용합니다.

6.4. 기준선 자기 정렬

행과 유사한 레이아웃 컨텍스트(공유 정렬 컨텍스트)에 참여하는 박스는 서로 기준선 정렬될 수 있습니다. 기준선 자기 정렬은 박스의 마진을 효과적으로 늘려 해당 박스의 정렬 기준선을 동일 기준선 공유 그룹 내 다른 박스의 기준선과 맞춥니다.

기준선 자기 정렬에 참여하는 박스 집합은 레이아웃 모델에 따라 다릅니다:

플렉스 아이템:
플렉스 아이템은 계산된 align-selffirst baseline 또는 last baseline일 때, 해당 플렉스 라인 내에서 기준선 자기 정렬에 참여함. 자세한 내용은 [CSS-FLEXBOX-1] 참고.
그리드 아이템:
그리드 아이템align-self 또는 justify-self 속성(각각)이 first baseline 또는 last baseline으로 계산될 때, 해당 행 또는 열의 시작/끝에서 기준선 자기 정렬에 참여함.

정확한 세부사항은 § 9.3 박스의 기준선 정렬 참고. 기준선 자기 정렬은 박스의 고유 크기 기여도를 늘릴 수 있습니다.

6.5. static-position 인셋을 가진 절대 위치 박스의 크기 조정 영향

인라인 축 오프셋이 모두 auto인 절대 위치 박스의 경우, 사용 가능한 공간inline 크기를 계산할 때 정렬의 영향을 받습니다.

참고: [CSS2]에서는 사용 가능한 공간direction 속성에서 결정됩니다. (CSS2§10.3.7, CSS2§10.3.8 참고.) 기본적으로 이 규칙들은 auto 인셋 중 하나(기본적으로 시작 가장자리 인셋)를 static-position 사각형의 해당 가장자리로 설정하고, 다른 하나는 포함 블록의 해당 가장자리(즉, 인셋을 0으로 설정)로 맞춥니다. self-alignment 속성포함 블록direction 참조를 대체해서 배치할 뿐 아니라, 여기서 지정한 대로 크기 조정의 참조도 대체합니다.

따라서 CSS2§10.3.7CSS2§10.3.8의 규칙을 해석할 때, direction 속성이 정적 위치 컨테이닝 블록에서 참조되는 모든 곳에서, 대신 align-self 또는 justify-self 속성 값(관련 축에 적용되는 속성)을 참조해야 하며, left와 동일한 정렬은 ltr로, right와 동일한 정렬은 rtl로 정의된 것처럼 처리해야 합니다. normalstart로 취급하고, 분배 정렬(distributed alignment) 값은 해당 대체 정렬(fallback alignment)로 처리합니다.

center 정렬의 경우, 박스에 대한 사용 가능한 공간정적 위치 사각형의 중심점과 관련 축에서 가장 가까운 컨테이닝 블록의 엣지 사이 거리의 두 배입니다.

Start alignment sizes into the space between
		          the start edge of the static-position rectangle and the end edge of the containing block.
		          End alignment sizes into the space between
		          the end edge of the static-position rectangle and the start edge of the containing block.
		          Center alignment sizes into the space between
		          the two edges of the static-position rectangle.
항상 inline-start static positioninline-end 포함 블록 가장자리 사이의 사용 가능한 공간 내에서 크기 조정하는 대신 ([CSS2] 기준), auto 인셋이 있는 절대 위치 요소는 지정된 자기 정렬에 가장 적합한 static-position 사각형의 가장자리 기준으로 크기 조정됩니다.
예를 들어, 박스의 포함 블록directionltr이고 자신의 justify-selfend이면, direction: rtl 규칙을 적용합니다; directionrtl이고 justify-contentspace-between이면, direction: rtl 규칙을 적용합니다; 등등. center(또는 동등값)의 경우, 양쪽 모두 static position과 일치시킵니다. 절대 위치 박스는 결과 공간(최소값 0) 내에서 크기 조정됩니다.

참고: align-self, justify-self 속성은 크기 조정의 추가 측면도 변경할 수 있습니다: 예를 들어 justify-self: stretchfit-content 크기 조정을 사용 가능한 공간에 맞춘 stretch-fit 크기로 대체합니다(모든 사용 가능한 공간을 소모). 이는 여기서의 사용 가능한 공간 조정과는 별개의 효과입니다.

참고: 이것은 절대 위치 박스의 크기 조정을 위한 사용 가능한 공간 계산에만 영향을 줍니다; 정렬 자체는 이전 섹션에서 정의한 대로 동작합니다.

7. 기본 정렬

align-itemsjustify-items 속성 (그리고 place-items 축약형) 은 요소의 자식 박스에 대한 기본 align-selfjustify-self 동작을 설정합니다.

그리드 아이템이 요소 내에서 정렬되는 것이 영향을 받는 다이어그램.

7.1. 인라인 축(또는 메인 축) 기본 정렬: justify-items 속성

이름: justify-items
값: normal | stretch | <baseline-position> | <overflow-position>? [ <self-position> | left | right ] | legacy | legacy && [ left | right | center ]
초기값: legacy
적용 대상: 모든 요소
상속: 아니오
백분율: 해당 없음
계산값: 지정된 키워드(단, legacy는 제외, 자세한 내용은 본문 참고)
정규 순서: 문법에 따라
애니메이션 타입: 불연속적

이 속성은 포맷팅 컨텍스트에 참여하는 모든 자식 박스(익명 박스 포함)에 대해 기본 justify-self를 지정합니다. 각 값의 의미는 다음과 같습니다:

legacy
이 키워드는 값이 자손에게 효과적으로 상속되도록 합니다.

legacy 키워드가 단독으로 나타날 경우 (left, right, center 키워드가 동반되지 않은 경우): justify-items상속 값legacy 키워드가 포함되어 있으면, 이 값은 상속 값으로 계산됨; 그렇지 않으면 normal로 계산됨.

justify-self:autojustify-items 값을 참조할 때, alignment 키워드만 참조하고 legacy 키워드는 참조하지 않습니다. 이것은 HTML의 <center> 요소와 align 속성의 legacy 정렬 동작을 구현하기 위해 존재합니다.

다른 값은 특별한 처리가 없으며 단순히 justify-self에서 참조됩니다.

7.2. 블록 축(또는 교차 축) 기본 정렬: align-items 속성

이름: align-items
값: normal | stretch | <baseline-position> | [ <overflow-position>? <self-position> ]
초기값: normal
적용 대상: 모든 요소
상속: 아니오
백분율: 해당 없음
계산값: 지정된 키워드
정규 순서: 문법에 따라
애니메이션 타입: 불연속적

이 속성은 포맷팅 컨텍스트에 참여하는 모든 자식 박스(익명 박스 포함)에 대해 기본 align-self를 지정합니다.

값은 특별한 처리가 없으며 단순히 align-self에서 참조됩니다.

7.3. 기본 정렬 축약형: place-items 속성

이름: place-items
값: <'align-items'> <'justify-items'>?
초기값: 각 속성별 참조
적용 대상: 모든 요소
상속: 아니오
백분율: 해당 없음
계산값: 각 속성별 참조
정규 순서: 문법에 따라
애니메이션 타입: 불연속적

축약형 속성align-itemsjustify-items를 한 번에 모두 선언합니다. 첫 번째 값은 align-items에 할당됩니다. 두 번째 값은 justify-items에 할당되며; 생략 시 첫 번째 값을 복사합니다.

8. 박스 사이의 간격

marginpadding을 사용해 개별 박스 주변의 시각적 간격을 지정할 수 있지만, 특정 레이아웃 컨텍스트 내에서 인접 박스 사이의 간격을 전역적으로 지정하는 것이 더 편리할 때가 있습니다. 특히 형제 박스 사이의 간격과 첫/마지막 박스와 컨테이너 가장자리 사이의 간격이 다를 때 유용합니다.

gap 속성, 그리고 그 row-gapcolumn-gap 하위 속성은 다단, 플렉스, 그리드 레이아웃에서 이런 기능을 제공합니다.

8.1. 행 및 열 거터: row-gap, column-gap 속성

이름: row-gap, column-gap
값: normal | <length-percentage [0,∞]>
초기값: normal
적용 대상: 다단 컨테이너, 플렉스 컨테이너, 그리드 컨테이너
상속: 아니오
백분율: § 8.3 gap 속성의 백분율 참고
계산값: 지정된 키워드, 아니면 계산된 <length-percentage>
정규 순서: 문법에 따라
애니메이션 타입: 계산값 타입에 따라

이 속성들은 컨테이너 내 아이템 사이의 고정 길이 거터를 지정하며, 아이템 사이에 공간을 추가합니다—​이는 space-between 키워드와 유사하지만, 남는 공간의 분수 대신 고정 크기를 사용합니다. column-gap 속성은 "열" 사이의 간격을 지정하며, 컨테이너의 인라인 축에서 박스 사이를 인라인 축 마진처럼 분리합니다; row-gap은 "행" 사이의 간격을 지정하며, 컨테이너의 block 축에서 박스 사이를 분리합니다.

각 값의 의미는 다음과 같습니다:

<length-percentage [0,∞]>

레이아웃 모드에 따라 "행" 또는 "열" 사이의 gap을 지정합니다; 자세한 내용은 아래 하위 섹션 참고.

음수 값은 무효입니다. 백분율의 경우, § 8.3 gap 속성의 백분율 참고.

normal

normal다단 컨테이너에서는 1em의 사용값, 그 외 모든 컨텍스트에서는 0px의 사용값을 의미합니다.

거터는 아이템 사이의 최소 간격을 제공합니다: 추가적인 간격은 justify-contentalign-content로 더해질 수 있습니다. 이 추가 공간은 거터 크기를 효과적으로 증가시킵니다.

이 속성들의 정확한 동작은 레이아웃 컨테이너별로 다릅니다:

다단 컨테이너
column-gap은 인접 거터를, 컬럼 박스 사이의 간격을 지정; [CSS-MULTICOL-1] 참고. row-gap거터column-boxcolumn-height로 생성한 행 사이에 지정; [CSS-MULTICOL-2] 참고.
플렉스 컨테이너
메인 축(main axis에 적용될 때, 예: row column-gap이 있는 flex 컨테이너)에서는, 아이템 사이의 구터(gutter)를 나타냅니다 (인접한 flex 아이템 사이에 고정 크기 마진이 하나 더 삽입된 것처럼 단일 행 내에서 동작합니다).

교차 축(cross axis에 적용될 때, 예: row row-gap이 있는 flex 컨테이너)에서는, 인접한 구터(gutter) 즉, flex 라인 사이의 구터를 나타냅니다.

grid 컨테이너
row-gapcolumn-gap 속성은 grid 컨테이너에 지정될 때, 구터그리드 행그리드 열 사이에 각각 정의합니다. 자세한 내용은 CSS Grid Layout 1 § 10.1 Gutters: the row-gap, column-gap, and gap properties 참고.

모든 경우에, 구터(gutter)단편화 분리(fragmentation break)와 일치하면 사라집니다. [CSS-BREAK-3]

참고: table 박스는 gap 속성으로 셀 사이 구분을 지정하지 않습니다. 대신 border-spacing 속성을 사용하며, 이는 기능이 조금 다릅니다: 상속되고, 테이블의 가장 바깥쪽 셀과 테이블 테두리 사이의 추가 간격도 지정합니다 (space-evenly와 비슷하지만 space-between과는 다릅니다).

8.2. Gap 축약형: gap 속성

이름: gap
값: <'row-gap'> <'column-gap'>?
초기값: 각 속성별 참조
적용 대상: 다단 컨테이너, 플렉스 컨테이너, 그리드 컨테이너
상속: 아니오
백분율: 콘텐츠 영역의 해당 차원을 기준으로 계산
계산값: 각 속성별 참조
정규 순서: 문법에 따라
애니메이션 타입: 계산값 타입에 따라

이 속성은 축약형으로, row-gapcolumn-gap을 한 번에 설정합니다. <'column-gap'>이 생략되면, <'row-gap'>과 같은 값으로 설정됩니다.

마진과 패딩이 눈에 보이는 거터 크기를 어떻게 더하는지 보여주는 다이어그램

참고: gap 속성은 박스 사이에 생성되는 “거터” 또는 “골목”의 눈에 보이는 구성 요소 중 하나일 뿐입니다. 마진, 패딩, 또는 분포 정렬의 사용은 gap에서 지정한 것 이상의 박스 사이 간격을 증가시킬 수 있습니다.

8.3. gap 속성의 백분율

일반적으로, gap 속성으로 도입된 gap은 gap의 크기를 가진 빈 아이템/트랙 등처럼 동작하도록 의도되었습니다; 즉, 저자는 gap의 효과를 단순히 추가 빈 아이템/트랙 등을 컨테이너에 삽입하여 재현할 수 있어야 합니다.

gap 속성의 백분율은 항상 해당 요소의 콘텐츠 박스의 해당 크기를 기준으로 계산됩니다. 이 크기가 명확할 때, 동작은 잘 정의되어 있고 레이아웃 모드 간에 일관됩니다. 하지만 레이아웃 모드마다 순환 백분율 크기를 아이템/트랙 등에서 다르게 처리하므로, gap도 마찬가지입니다:

그리드 레이아웃에서

최소 크기 속성 및 마진/패딩과 동일하게 [CSS-SIZING-3], 순환 백분율 크기는 고유 크기 기여도를 결정할 때는 0을 기준으로 계산하고, 박스의 콘텐츠를 레이아웃할 때는 박스의 콘텐츠 박스를 기준으로 계산합니다.

플렉스 레이아웃에서

순환 백분율 크기는 모든 경우에 0을 기준으로 계산됩니다.

8.4. 레거시 Gap 속성: grid-row-gap, grid-column-gap, grid-gap 속성

Grid Layout 모듈은 원래 자체 거터 속성 세트로 작성되었으며, 이후 모든 거터 속성이 기존 row-gap/column-gap 네이밍으로 통합되었습니다. 레거시 콘텐츠와의 호환성을 위해, 아래와 같이 grid 접두어가 붙은 이름도 지원해야 합니다:

9. 기준선 정렬 세부사항

기준선 공유 그룹의 박스들은 정렬 기준선을 사용해 서로 정렬됩니다. 예를 들어, 수평 쓰기 모드에서는, 동일 행의 테이블 셀에 align-content: baseline을 지정하면 각 셀의 첫 번째 형식화 라인의 기준선들이 정렬됩니다. 이 섹션에서는 국제화된 현대 CSS에서 존재하는 다양한 기준선과 쓰기 모드를 고려해 기준선 정렬이 정확히 어떻게 수행되는지 정의합니다.

baseline set은 공통 기준선 테이블과 연관된 여러 기준선(알파벳, 중앙 등)의 집합입니다. 일반적으로 조판 전통은 이 중 하나만 사용하지만, 서로 다른 쓰기 시스템은 서로 다른 기준선을 사용하고, 쓰기 시스템을 혼합하면 하나의 라인 내에서 둘 이상의 기준선을 사용할 수도 있습니다. 자세한 기준선과 쓰기 모드 정보는 CSS Writing Modes 3 § 4.1 기준선 소개 참고.

9.1. 박스의 기준선 결정

박스마다, 특정 축에 대해, first baseline set(및 last baseline set) 을 가질 수 있고, 이는 박스 내의 첫/마지막 텍스트 행의 baseline set에 해당합니다. alignment baseline은 박스가 정렬 컨텍스트 내에서 정렬되는 데 사용하는 기준선으로, baseline set 중 하나이며 일반적으로 공유 정렬 컨텍스트와 연관된 주요 기준선입니다. (자세한 내용은 dominant-baselinealignment-baseline 속성을 [CSS-INLINE-3]에서 참고.)

박스의 첫/마지막 baseline set은 레이아웃 모델에 따라 다음과 같이 다르게 결정됩니다:

라인 박스
라인 박스의 첫 번째/마지막 베이스라인 집합은 지배적인 베이스라인과 해당 루트 인라인 박스의 글꼴 설정에서 생성됩니다.
블록 컨테이너
블록 컨테이너의 첫 번째/마지막 베이스라인 집합은 블록 컨테이너 안의 첫 번째/마지막 in-flow 라인 박스 또는 블록 컨테이너 안의 베이스라인 집합을 제공하는 첫 번째/마지막 in-flow 블록 레벨 자식에서 가져오며, 둘 중 먼저/나중에 오는 것을 사용합니다. 해당 라인 박스나 자식이 없으면, 그 블록 컨테이너는 베이스라인 집합을 갖지 않습니다.

단, 레거시 사유로 baseline-source 속성이 auto일 때(초기값) 블록 레벨 또는 인라인 레벨 블록 컨테이너스크롤 컨테이너라면 항상 마지막 베이스라인 집합을 가지며, 이 베이스라인들은 모두 그 block-end 마진 에지와 일치합니다.

다단 컨테이너
다단(multi-column) 컨테이너의 첫 번째 베이스라인 집합column 또는 다단 스패너다단 컨테이너정렬 베이스라인에 해당하는 block-start–방향 가장 높은 베이스라인을 갖는 첫 번째 베이스라인 집합에서 가져옵니다. 해당 라인 박스나 자식이 없으면, 다단 컨테이너는 첫 번째 베이스라인 집합이 없습니다.

마지막 베이스라인 집합도 유사하게 동작하지만, 마지막 베이스라인 집합block-end–방향 가장 낮은 베이스라인을 사용합니다.

테이블
테이블 박스의 첫 번째/마지막 베이스라인 집합은 자체 첫 번째/마지막 행의 첫 번째/마지막 베이스라인 집합입니다.

인라인 블록의 첫 번째/마지막 베이스라인 집합을 찾을 때 테이블 박스가 제공하는 베이스라인은 건너뛰어야 합니다. (이 특성은 [CSS2]의 레거시 행위입니다.)

테이블 행
해당 행의 셀 중 하나라도 first baseline/last baseline 정렬에 참여하며 인라인 축을 따라 정렬된다면, 행의 첫 번째/마지막 베이스라인 집합은 이들이 공유하는 정렬 베이스라인과 행의 최초 사용 가능 글꼴에서 정렬 후 생성됩니다. 그렇지 않으면 행의 첫 번째/마지막 베이스라인 집합은 그 행의 셀들 중 가장 낮은/높은 콘텐츠 에지로부터 합성됩니다. [CSS2]

스팬하는 셀은 first baseline/last baseline을 위해 자신이 span하는 첫 번째/마지막 행에만 참여합니다.

플렉스 컨테이너
Flex Baselines([CSS-FLEXBOX-1]) 참고.
그리드 컨테이너
Grid Baselines([CSS-GRID-1]) 참고.

박스에서 단일 기준선으로 generate baselines하려면, 박스의 폰트 설정과 첫 사용 가능한 폰트의 기준선 테이블을 사용하고, 해당 기준선 set을 주어진 단일 기준선에 맞추면 됩니다.

기준선 정렬에 참여하는 박스에 baseline set이 없으면, alignment baselinesynthesized 규칙에 따라 포맷팅 컨텍스트에 따라 합성됩니다. synthesize baselines하려면 사각형(또는 두 평행선)에서 알파벳 기준선은 line-under에서, 중앙 기준선은 두 가장자리 또는 라인의 위치를 평균해서 합성합니다. 추가 기준선 합성 규칙은 CSS Inline Layout 3 § A Alignment Metrics 합성 참고.

참고: 박스에서 기준선 합성에 사용하는 가장자리는 포맷팅 컨텍스트에 따라 다릅니다: 인라인 레벨 박스는 마진 가장자리에서 합성, 테이블 셀은 콘텐츠 가장자리에서 합성, 그리드·플렉스 아이템은 테두리 가장자리에서 합성합니다.

일반적으로, 정렬되는 박스, 도형 등은 쓰기 모드를 사용해 line-underline-over 가장자리를 결정합니다. 단, 쓰기 모드block flow 방향이 정렬 컨텍스트의 축과 평행할 때는, 축 호환 쓰기 모드를 가정해야 합니다:

박스의 베이스라인을 찾기 위해, 박스와 모든 레이아웃 흐름 내(in-flow) 자손 중 스크롤 메커니즘이 있는 것(overflow 속성 참고)은 초기 스크롤 위치에 도달한 것처럼 취급되어야 합니다. 또한, 스크롤 컨테이너의 첫 번째/마지막 베이스라인 위치가 그 컨테이너의 border edge 바깥에 있을 경우, 해당 베이스라인의 위치는 border edge에 맞게 고정(clamp)됩니다.

9.2. 기준선 정렬 그룹화

baseline-sharing group은 기준선 정렬에 함께 참여하는 박스들로 구성됩니다. 이는 아래 두 조건을 모두 만족할 때만 가능합니다:

참고: 기준선 콘텐츠 정렬에 참여하는 박스와 기준선 자기 정렬에 참여하는 박스는 같은 baseline-sharing group에 속할 수 있으며, 서로 정렬 가능합니다. 두 방법의 차이는 정렬을 위해 추가 공간이 어디에 삽입되는지(박스 경계 내부/외부)에 있습니다.

박스들은 특정 축에서, 특정 박스에 의해 설정된 공유 정렬 컨텍스트를 공유할 때 다음과 같은 경우에 해당합니다:

참고: 개념적으로, line box 내 인라인 레벨 박스들도 자기 정렬 컨텍스트를 공유하며 기준선 그룹에 참여합니다; 다만 이들은 본 모듈의 속성이 아니라 vertical-align 속성에만 반응해 기준선 정렬됩니다. 자세한 내용은 [CSS-INLINE-3] 참고.

박스가 여러 공유 정렬 컨텍스트에 걸쳐 있으면, 해당 축에서 시작/끝 쪽 공유 정렬 컨텍스트 내에서 first/last 기준선 정렬에 참여합니다. 예를 들어, 3개 행을 스팬하는 테이블 셀은 첫 행의 셀들과 first-baseline 정렬에, 마지막 행의 셀들과 last-baseline 정렬에 각각 참여합니다.

두 박스가 baseline-sharing group에 있을 때의 기준선 정렬 선호도호환됨이란 다음과 같은 경우입니다:

9.3. 박스의 기준선 정렬 방법

하나의 베이스라인 공유 그룹(baseline-sharing group)에 속하는 정렬 주체들과 그들의 베이스라인 집합에 대해, 정렬 주체들은 아래와 같이 베이스라인 맞춤(baseline-align) 처리됩니다:

  1. 베이스라인 공유 그룹의 베이스라인 표(baseline table)는 그룹의 최초 사용 가능 글꼴정렬 문맥(alignment context)에서 생성하고, 중앙 베이스라인(central baseline)끼리 맞춰 이 베이스라인 표의 미러(mirror)도 오버레이합니다. 이들이 바로 정렬 주체들이 맞춰질 베이스라인 "그리드"입니다.

  2. 정렬 주체를 지정된 정렬 베이스라인에 맞게 그룹의 베이스라인 표 또는 미러에 정렬합니다. (정렬 주체라인 방향(line orientation)에 따라 더 잘 맞는 쪽 사용) 별도 지정이 없는 한 (예: alignment-baseline 속성 등), 정렬 베이스라인문맥의 지배적 베이스라인(dominant baseline)입니다.

  3. 정렬된 베이스라인 공유 그룹정렬 컨테이너 안에서 해당 대체 정렬(fallback alignment)에 따라 배치합니다. 베이스라인 공유 그룹대체 정렬(fallback alignment)은 해당 아이템들의 대체 정렬(fallback alignment)물리적 방향(physical directions)에 맞춰 해석된 것입니다.

  4. 첫 번째/마지막 베이스라인 콘텐츠 정렬(baseline content-alignment)의 경우, 모든 정렬 컨테이너의 시작/끝 마진 에지가 정렬 컨테이너의 시작/끝 콘텐츠 에지에서 맞춰지도록, 추가적으로 필요한 최소 공간을 더해주어야 하며, 베이스라인 공유 그룹 내에서 베이스라인 정렬이 유지되도록 해야 합니다.

부록 A: static position 용어

특정 축의 두 inset 속성이 모두 auto로 된 절대 위치 박스의 경우, CSS2는 정적 위치를 사용해 박스의 크기와 위치를 결정합니다. CSS2.1§10.3.7 참고. 박스 정렬 속성은 다른 레이아웃 모드에서 크기 및 위치 계산을 변경하는 것처럼 이러한 계산에도 영향을 미칩니다. 이러한 변경은 정적 위치 사각형(static-position rectangle)을 참조합니다. 이 사각형의 각 면은 박스가 자신의 컨테이닝 블록의 각 면에서 갖는 정적 위치를 나타냅니다.

static-position rectangle과 그에 대응하는 static position은 “가상 박스”의 레이아웃 모델에 따라 정의됩니다:

블록 레이아웃
static positionblock-level 박스에 대해 [CSS2] 10장에 정의됨. static-position rectangle은 박스의 static-position 포함 블록(CSS2§10.3.7 참고)의 인라인 축 양쪽에 걸친 두께 0의 사각형이며, block-start static position(CSS2§10.6.4 참고)에 위치함.
인라인 레이아웃
static positioninline-level 박스에 대해 [CSS2] 10장에 정의됨. static-position rectangle은 “가상 박스”가 포함될 line box의 line-over/line-under 양쪽에 걸친 두께 0의 사각형이며 (CSS2§10.3.7 참고), inline-start static position에 위치함.
플렉스 레이아웃
static-position rectangle플렉스 컨테이너의 자식에 대해 플렉스 컨테이너콘텐츠 edge에 대응함. 자세한 내용은 CSS Flexbox 1 § 4.1 절대 위치 플렉스 자식 참고.
그리드 레이아웃
기본적으로 static-position rectangle그리드 컨테이너의 자식에 대해 그리드 컨테이너콘텐츠 edge에 대응함. 단, 해당 그리드 컨테이너가 박스의 실제 포함 블록도 생성할 경우, 그리드 영역(grid-placement 속성으로 지정)이 static-position rectangle을 설정함. 자세한 내용은 그리드 컨테이너 자식의 static position[CSS-GRID-1]에서 참고.

10. 변경 사항

2025년 3월 11일 워킹 드래프트(11 March 2025 Working Draft) 이후 변경 사항은 다음과 같습니다:

이전 변경 사항도 참고하세요.

11. 개인정보 고려사항

간단한 레이아웃 명세로, 새로운 개인정보 고려사항을 도입하지 않습니다.

12. 보안 고려사항

간단한 레이아웃 명세로, 새로운 보안 고려사항을 도입하지 않습니다.

감사의 글

특별한 감사는 David Baron, Javier Fernandez, Markus Mielke, Alex Mogilevsky, 그리고 CSSWG의 2008년 3월 F2F alignment 토론에 참여해주신 분들께 드립니다. 이들이 이 문서에 서술된 정렬 모델에 기여해주셨으며, Melanie Richards에게는 다양한 정렬 키워드의 일러스트를 그려주신 점에 감사드립니다.

적합성

문서 규약

준수 요구사항은 설명적 단언과 RFC 2119 용어를 조합하여 표현됩니다. 핵심 단어 “MUST”, “MUST NOT”, “REQUIRED”, “SHALL”, “SHALL NOT”, “SHOULD”, “SHOULD NOT”, “RECOMMENDED”, “MAY”, “OPTIONAL”은 문서의 규범적 부분에서 RFC 2119에서 정의된 대로 해석되어야 합니다. 단, 가독성을 위해 이 단어들은 명세서에서 모두 대문자로 표기되지 않습니다.

이 명세의 모든 텍스트는 명시적으로 비규범적, 예시, 주석으로 표시된 섹션을 제외하고는 규범적입니다. [RFC2119]

이 명세서의 예시는 “예를 들어(for example)”라는 말로 시작하거나, 또는 class="example"와 같이 규범적 텍스트와 분리되어 표시됩니다.

이것은 정보 제공용 예시입니다.

정보 제공용 주석은 “참고(Note)”라는 단어로 시작하며, class="note"로 규범적 텍스트와 구분되어 표시됩니다:

참고, 이것은 정보 제공용 주석입니다.

권고(advisement)는 규범적 섹션으로 특별한 주의를 유도하도록 스타일링되며, <strong class="advisement">로 다른 규범적 텍스트와 구분되어 표시됩니다: UA는 반드시 접근 가능한 대체 수단을 제공해야 합니다.

적합성 클래스

이 명세서 준수는 세 가지 준수 클래스로 정의됩니다:

스타일 시트
CSS 스타일 시트.
렌더러
UA로, 스타일 시트의 의미를 해석하고 이를 사용하는 문서를 렌더링합니다.
저작 도구
UA로, 스타일 시트를 작성합니다.

스타일 시트는 본 명세서에 준수하려면 이 모듈에서 정의한 문법과 각 기능의 개별 문법에 따라 모든 구문이 올바른 경우에 해당합니다.

렌더러는 본 명세서에 준수하려면 스타일 시트를 적절한 명세서 정의대로 해석하는 것 외에도, 본 명세서가 정의하는 모든 기능을 올바르게 파싱 및 렌더링해야 합니다. 단, UA가 기기의 한계로 인해 문서를 올바르게 렌더링하지 못하더라도, UA가 비준수로 간주되지 않습니다. (예: UA가 흑백 모니터에서 색상을 렌더링할 필요는 없음.)

저작 도구는 본 명세서에 준수하려면 이 모듈에서 정의한 문법과 각 기능의 개별 문법에 따라 스타일 시트를 올바르게 작성하고, 본 모듈에서 설명한 스타일 시트의 준수 요구사항을 모두 충족해야 합니다.

부분 구현

작성자가 미래 호환 파싱 규칙을 활용해 fallback 값을 지정할 수 있도록, CSS 렌더러는 반드시 사용 가능한 수준의 지원이 없는 at-rule, 속성, 속성값, 키워드, 기타 구문 구조를 무효로 간주하고 적절하게 무시해야 합니다. 특히, 사용자 에이전트는 반드시 다중 값 속성 선언에서 지원하지 않는 값만 선택적으로 무시하고 지원하는 값은 적용해서는 안 됩니다: 어떤 값이 무효(지원하지 않는 값)로 간주되면, CSS는 전체 선언을 무시해야 함을 요구합니다.

불안정 및 독점적 기능 구현

향후 안정적인 CSS 기능과의 충돌을 피하기 위해, CSSWG는 모범 사례에 따라 불안정 기능 및 독점 확장을 구현할 것을 권고합니다.

비실험적 구현

명세가 Candidate Recommendation 단계에 도달하면, 비실험적 구현이 가능하며, 구현자는 명세에 맞게 올바르게 구현함을 입증할 수 있는 CR 레벨 기능은 접두사 없는 구현을 발표해야 합니다.

CSS의 구현 간 상호운용성을 확립 및 유지하기 위해, CSS 워킹 그룹은 비실험적 CSS 렌더러가 W3C에 구현 보고서(필요시 해당 테스트케이스 포함)를 제출한 후 CSS 기능의 접두사 없는 구현을 배포할 것을 요청합니다. W3C에 제출된 테스트케이스는 CSS 워킹 그룹의 검토 및 수정 대상이 됩니다.

테스트케이스 및 구현 보고서 제출에 대한 추가 정보는 CSS 워킹 그룹 웹사이트 https://www.w3.org/Style/CSS/Test/에서 확인할 수 있습니다. 질문은 public-css-testsuite@w3.org 메일링 리스트로 문의하세요.

색인

이 명세서에서 정의된 용어

참조로 정의된 용어

참고 문헌

규범적 참고 문헌

[CSS-ANCHOR-POSITION-1]
Tab Atkins Jr.; Elika Etemad; Ian Kilpatrick. CSS 앵커 위치 지정 모듈 1단계(CSS Anchor Positioning Module Level 1). 2025년 12월 22일. WD. URL: https://www.w3.org/TR/css-anchor-position-1/
[CSS-BOX-4]
Elika Etemad. CSS 박스 모델 모듈 4단계(CSS Box Model Module Level 4). 2024년 8월 4일. WD. URL: https://www.w3.org/TR/css-box-4/
[CSS-BREAK-4]
Rossen Atanassov; Elika Etemad. CSS 단편화 모듈 4단계(CSS Fragmentation Module Level 4). 2018년 12월 18일. FPWD. URL: https://www.w3.org/TR/css-break-4/
[CSS-CASCADE-5]
Elika Etemad; Miriam Suzanne; Tab Atkins Jr.. CSS 계단식 스타일 및 상속 5단계(Cascading and Inheritance Level 5). 2022년 1월 13일. CR. URL: https://www.w3.org/TR/css-cascade-5/
[CSS-DISPLAY-4]
Elika Etemad; Tab Atkins Jr.. CSS 디스플레이 모듈 4단계(CSS Display Module Level 4). 2025년 11월 6일. WD. URL: https://www.w3.org/TR/css-display-4/
[CSS-FLEXBOX-1]
Elika Etemad; Tab Atkins Jr.; Rossen Atanassov. CSS 플렉스 박스 레이아웃 모듈 1단계(Flexible Box Layout Module Level 1). 2025년 10월 14일. CRD. URL: https://www.w3.org/TR/css-flexbox-1/
[CSS-FONTS-4]
Chris Lilley. CSS 폰트 모듈 4단계(CSS Fonts Module Level 4). 2024년 2월 1일. WD. URL: https://www.w3.org/TR/css-fonts-4/
[CSS-GRID-1]
Tab Atkins Jr.; et al. CSS 그리드 레이아웃 모듈 1단계(CSS Grid Layout Module Level 1). 2025년 3월 26일. CRD. URL: https://www.w3.org/TR/css-grid-1/
[CSS-GRID-2]
Tab Atkins Jr.; et al. CSS 그리드 레이아웃 모듈 2단계(CSS Grid Layout Module Level 2). 2025년 3월 26일. CRD. URL: https://www.w3.org/TR/css-grid-2/
[CSS-INLINE-3]
Elika Etemad. CSS 인라인 레이아웃 모듈 3단계(CSS Inline Layout Module Level 3). 2024년 12월 18일. WD. URL: https://www.w3.org/TR/css-inline-3/
[CSS-LOGICAL-1]
Elika Etemad; Rossen Atanassov. CSS 논리 속성 및 값 모듈 1단계(CSS Logical Properties and Values Module Level 1). 2025년 12월 4일. WD. URL: https://www.w3.org/TR/css-logical-1/
[CSS-MULTICOL-1]
Florian Rivoal; Rachel Andrew. CSS 다단 레이아웃 모듈 1단계(Multi-column Layout Module Level 1). 2024년 5월 16일. CR. URL: https://www.w3.org/TR/css-multicol-1/
[CSS-MULTICOL-2]
Florian Rivoal; Rachel Andrew. CSS 다단 레이아웃 모듈 2단계(Multi-column Layout Module Level 2). 2024년 12월 19일. FPWD. URL: https://www.w3.org/TR/css-multicol-2/
[CSS-OVERFLOW-3]
Elika Etemad; Florian Rivoal. CSS 오버플로우 모듈 3단계(CSS Overflow Module Level 3). 2025년 10월 7일. WD. URL: https://www.w3.org/TR/css-overflow-3/
[CSS-POSITION-3]
Elika Etemad; Tab Atkins Jr.. CSS 위치 지정 레이아웃 모듈 3단계(Positioned Layout Module Level 3). 2025년 10월 7일. WD. URL: https://www.w3.org/TR/css-position-3/
[CSS-POSITION-4]
Elika Etemad; Tab Atkins Jr.. CSS 위치 지정 레이아웃 모듈 4단계(Positioned Layout Module Level 4). 2025년 10월 7일. WD. URL: https://www.w3.org/TR/css-position-4/
[CSS-SIZING-3]
Tab Atkins Jr.; Elika Etemad. CSS 박스 크기 지정 모듈 3단계(Box Sizing Module Level 3). 2021년 12월 17일. WD. URL: https://www.w3.org/TR/css-sizing-3/
[CSS-SIZING-4]
Tab Atkins Jr.; Elika Etemad; Jen Simmons. CSS 박스 크기 지정 모듈 4단계(Box Sizing Module Level 4). 2021년 5월 20일. WD. URL: https://www.w3.org/TR/css-sizing-4/
[CSS-TEXT-3]
Elika Etemad; Koji Ishii; Florian Rivoal. CSS 텍스트 모듈 3단계(CSS Text Module Level 3). 2024년 9월 30일. CRD. URL: https://www.w3.org/TR/css-text-3/
[CSS-VALUES-3]
Tab Atkins Jr.; Elika Etemad. CSS 값 및 단위 모듈 3단계(Values and Units Module Level 3). 2024년 3월 22일. CRD. URL: https://www.w3.org/TR/css-values-3/
[CSS-VALUES-4]
Tab Atkins Jr.; Elika Etemad. CSS 값 및 단위 모듈 4단계(Values and Units Module Level 4). 2024년 3월 12일. WD. URL: https://www.w3.org/TR/css-values-4/
[CSS-WRITING-MODES-3]
Elika Etemad; Koji Ishii. CSS 쓰기 모드 3단계(CSS Writing Modes Level 3). 2019년 12월 10일. REC. URL: https://www.w3.org/TR/css-writing-modes-3/
[CSS-WRITING-MODES-4]
Elika Etemad; Koji Ishii. CSS 쓰기 모드 4단계(CSS Writing Modes Level 4). 2019년 7월 30일. CR. URL: https://www.w3.org/TR/css-writing-modes-4/
[CSS2]
Bert Bos; et al. 계단식 스타일시트 2단계 개정 1판(Cascading Style Sheets Level 2 Revision 1 (CSS 2.1) Specification). 2011년 6월 7일. REC. URL: https://www.w3.org/TR/CSS2/
[ECMA-426]
소스 맵 형식 명세(Source map format specification). Editor's Draft. URL: https://tc39.es/ecma426/
[RFC2119]
S. Bradner. RFC에서 요구 수준을 나타내는 키워드(Key words for use in RFCs to Indicate Requirement Levels). 1997년 3월. Best Current Practice. URL: https://datatracker.ietf.org/doc/html/rfc2119
[SELECTORS-3]
Tantek Çelik; et al. 셀렉터 3단계(Selectors Level 3). 2018년 11월 6일. REC. URL: https://www.w3.org/TR/selectors-3/

참고용 참고 문헌

[CSS-BREAK-3]
Rossen Atanassov; Elika Etemad. CSS 단편화 모듈 3단계. 2018년 12월 4일. CR. URL: https://www.w3.org/TR/css-break-3/
[CSS-DISPLAY-3]
Elika Etemad; Tab Atkins Jr.. CSS Display 모듈 3단계. 2023년 3월 30일. CR. URL: https://www.w3.org/TR/css-display-3/
[CSSOM-1]
Daniel Glazman; Emilio Cobos Álvarez. CSS 오브젝트 모델 (CSSOM). 2021년 8월 26일. WD. URL: https://www.w3.org/TR/cssom-1/

속성 색인

이름 초기값 적용 대상 상속 백분율 애니메이션 타입 정식 순서 계산된 값
align-content normal | <baseline-position> | <content-distribution> | <overflow-position>? <content-position> normal 블록 컨테이너, 다단 컨테이너, 플렉스 컨테이너, 그리드 컨테이너 아니오 해당 없음 불연속(discrete) 문법에 따름 명시된 키워드
align-items normal | stretch | <baseline-position> | <overflow-position>? <self-position> normal 모든 요소 아니오 해당 없음 불연속(discrete) 문법에 따름 명시된 키워드
align-self auto | <overflow-position>? [ normal | <self-position> ]| stretch | <baseline-position> auto 플렉스 아이템, 그리드 아이템, 절대 위치 박스 아니오 해당 없음 불연속(discrete) 문법에 따름 명시된 키워드
column-gap normal | <length-percentage [0,∞]> normal 다단 컨테이너, 플렉스 컨테이너, 그리드 컨테이너 아니오 참조 계산값 유형에 따름 문법에 따름 명시된 키워드 아니면 계산된 <length-percentage> 값
gap <'row-gap'> <'column-gap'>? 각 속성 별로 참조 다단 컨테이너, 플렉스 컨테이너, 그리드 컨테이너 아니오 콘텐츠 영역 대응 치수 참조 계산값 유형에 따름 문법에 따름 각 속성 별로 참조
justify-content normal | <content-distribution> | <overflow-position>? [ <content-position> | left | right ] normal 다단 컨테이너, 플렉스 컨테이너, 그리드 컨테이너 아니오 해당 없음 불연속(discrete) 문법에 따름 명시된 키워드
justify-items normal | stretch | <baseline-position> | <overflow-position>? [ <self-position> | left | right ] | legacy | legacy && [ left | right | center ] legacy 모든 요소 아니오 해당 없음 불연속(discrete) 문법에 따름 명시된 키워드 (legacy 제외, 자세한 내용은 설명 참고)
justify-self auto | <overflow-position>? [ normal | <self-position> | left | right ] | stretch | <baseline-position> auto 블록 레벨 박스, 절대 위치 박스, 그리드 아이템 아니오 해당 없음 불연속(discrete) 문법에 따름 명시된 키워드
place-content <'align-content'> <'justify-content'>? normal 각 속성 별로 참조 아니오 해당 없음 불연속(discrete) 문법에 따름 각 속성 별로 참조
place-items <'align-items'> <'justify-items'>? 각 속성 별로 참조 모든 요소 아니오 해당 없음 불연속(discrete) 문법에 따름 각 속성 별로 참조
place-self <'align-self'> <'justify-self'>? auto 각 속성 별로 참조 아니오 해당 없음 불연속(discrete) 문법에 따름 각 속성 별로 참조
row-gap normal | <length-percentage [0,∞]> normal 다단 컨테이너, 플렉스 컨테이너, 그리드 컨테이너 아니오 참조 계산값 유형에 따름 문법에 따름 명시된 키워드 아니면 계산된 <length-percentage> 값

이슈 색인

"start"와 "end"의 직교 흐름에서의 이중 축 특성을 쉽게 이해할 수 있도록 개선 필요.
예시 이미지를 여기에 추가하세요.
“스마트” 기본 동작을 구현하는 것이 웹 호환성이 없을 수도 있음(가능성이 높다고 생각하지만). 이에 대한 피드백은 WG에 전달해야 함. “스마트” 기본 동작을 구현하지 않은 UA는 safealign-contentblock containers에 적용해야 하며, 그 외에는 unsafe로 동작해야 함.
이 이미지도 교체하세요.