aboutsummaryrefslogtreecommitdiff
path: root/files/ko/web/css/css_containment/index.html
blob: bbfe8f3e7cde905e34b8a5451b72744337528f72 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
---
title: CSS Containment
slug: Web/CSS/CSS_Containment
translation_of: Web/CSS/CSS_Containment
---
<p>{{CSSRef}}<br>
 CSS Containment 사양의 목표는 개발자가 페이지의 하위 트리(subtree)를 페이지의 나머지 부분과 분리할 수 있도록 하여 웹 페이지의 성능을 향상시키는 것입니다. 브라우저가 페이지의 일부가 독립적임을 인식하면 렌더링을 최적화 하고 성능을 개선 할 수 있습니다. 사양은 단일 CSS 속성(property) {{cssxref("contain")}}을 정의합니다. 이 문서는 사양의 기본 목표를 설명합니다.</p>

<h2 id="기본_예제">기본 예제</h2>

<p>많은 웹 페이지에는 서로 독립적인 여러 섹션이 포함되어 있습니다. 예를들면 아래 마크업에서와 같이 아티클, 헤드라인, 콘텐츠 로 이루어진 목록입니다.</p>

<pre class="brush: html notranslate">&lt;h1&gt;My blog&lt;/h1&gt;
&lt;article&gt;
  &lt;h2&gt;Heading of a nice article&lt;/h2&gt;
  &lt;p&gt;Content here.&lt;/p&gt;
&lt;/article&gt;
&lt;article&gt;
  &lt;h2&gt;Another heading of another article&lt;/h2&gt;
  &lt;p&gt;More content here.&lt;/p&gt;
&lt;/article&gt;</pre>

<p>각 아티클에는 CSS에서 {{cssxref("contain")}} 속성의 값으로 <code>content</code> 가 적용되어 있습니다.</p>

<pre class="brush: css notranslate">article {
  contain: content;
}</pre>

<p>각 아티클은 페이지의 다른 아티클과 독립적이므로 브라우저에 이러한 사실을 알리기 위해 <code>contain: content</code>가 포함되어 있습니다. 그러면 브라우저는 이 정보를 사용하여 컨텐츠를 렌더링하는 방법을 결정할 수 있습니다. 예를들어 볼 수 있는 영역 밖에있는 아티클은 렌더링하지 않을 수 있습니다. </p>

<p>각 <code>&lt;article&gt;</code> 에 <code>contain</code> 속성의 값을 <code>content</code> 로 제공하면, 새 요소(element)가 삽입될 때 브라우저는 containing 요소들의 하위 트리 외부 영역을 relayout(reflow)하거나 repaint 할 필요가 없음을 인식합니다. <code>&lt;article&gt;</code> 이 내용에 따라 크기가 달라지도록 스타일을 지정하더라도(예: <code>height: auto</code>), 브라우저는 크기 변경을 고려해야 할 수 있습니다.</p>

<p>우리는 <code>contain</code> 속성을 통해 각 아티클이 독립적이라고 말했습니다.</p>

<p><code>content</code> 값은 <code>contain: layout paint</code>의 약어입니다. 브라주어에 요소의 내부 레이아웃이 페이지의 나머지 부분과 완전히 분리되어 있으며, 요소에 대한 모든 것이 경계 내부에 그려져 있음을 알려줍니다. overflow되어 보이는 것이 없습니다.</p>

<p>이 정보는 페이지를 작성하는 웹 개발자에게 일반적으로 알려져 있으며, 사실 매우 분명합니다. 그러나 브라우저는 귀하의 의도를 추측할 수 없고, 아티클이 완전히 독립적일 것이라고 가정할 수 없습니다. 따라서 이 속성은 브라우저에게 이 사실을 설명하고, 그 정보를 기반으로 성능 최적화를 수행할 수 있는 좋은 방법을 제공합니다.</p>

<h2 id="주요_개념_및_용어">주요 개념 및 용어</h2>

<p>이 사양은 오로지 {{cssxref("contain")}} 이라는 하나의 속성(property)만 정의합니다. 이 속성의 값은 해당 요소에 적용 할 포함 유형을 나타냅니다.</p>

<h3 id="Layout_containment">Layout containment</h3>

<pre class="brush: css notranslate">article {
  contain: layout;
}</pre>

<p>Layout 은 일반적으로 전체 문서로 범위가 지정됩니다. 즉, 하나의 요소를 이동하면 전체 문서를 다른 곳으로 이동할 수 있는 것처럼 처리해야 합니다. 그러나 <code>contain: layout</code> 을 사용하면 브라우저에 이 요소만 확인하면 된다고 알려줄 수 있습니다. 요소 내부의 모든 항목은 해당 요소로 범위가 지정되고, 페이지의 나머지 부분에는 영향을 주지 않습니다. 그리고 containing box는 독립적인 formatting context를 설정합니다.</p>

<p>추가사항</p>

<ul>
 <li><code>float</code> 레이아웃은 독립적으로 수행됩니다.</li>
 <li>Margin 이 layout containment 경계를 가로질러 병합(collapse)되지 않습니다.</li>
 <li>layout 컨테이너는 position: <code>absolute</code>/<code>fixed</code> 의 하위 항목에 대한 containing block이 됩니다.</li>
 <li>containing box는 stacking context를 생성합니다. 따라서 {{cssxref("z-index")}} 를 사용할 수 있습니다.</li>
</ul>

<h3 id="Paint_containment">Paint containment</h3>

<pre class="brush: css notranslate">article {
  contain: paint;
}</pre>

<p>Paint containment 는 기본적으로 박스를 주요 박스(principal box)의 패딩 경계에 클립(clip - 맞춰서 채우기)합니다. overflow되어 보이는 것이 없습니다. <code>paint</code> containment 도 <code>layout</code> containment 와 마찬가지입니다. (위 참조).</p>

<p>또다른 장점은 containing box가 화면 밖에 있으면, 브라우저가 contained 요소를 paint 할 필요가 없다는 것입니다. 이 때 요소가 box에 포함되어 있으므로 화면에 표시되지 않아야 합니다.</p>

<h3 id="Size_containment">Size containment</h3>

<pre class="brush: css notranslate">article {
  contain: size;
}</pre>

<p>Size containment 는 자체적으로 사용될 때 성능 최적화 방법을 많이 제공하지 않습니다. 그러나 이는 요소의 자식 크기가 요소 자체의 크기에 영향을 줄 수 없음을 의미합니다. 요소의 크기는 자식이 존재하지 않는 것처럼 계산됩니다.</p>

<p><code>contain: size</code> 를 적용하면, 이를 적용한 요소의 크기도 지정해야 합니다. 수동으로 크기를 지정하지 않으면, 대부분의 경우 크기가 0이 됩니다.</p>

<h3 id="Style_containment">Style containment</h3>

<pre class="brush: css notranslate">article {
  contain: style;
}</pre>

<p>style containment 는 이름에도 불구하고 <a href="/ko/docs/Web/Web_Components/Using_shadow_DOM">Shadow DOM</a>에서 얻을 수 있는 범위(scope) 스타일을 제공하지 않습니다. 주요 사용 사례는, 요소에서 <a href="/ko/docs/Web/CSS/CSS_Lists_and_Counters/Using_CSS_counters">CSS Counter</a> 가 변경되어 나머지 트리에 영향을 미칠 수 있는 상황을 방지하는 것입니다.</p>

<p><code>contain: style</code> 을 사용하면 {{cssxref("counter-increment")}}{{cssxref("counter-set")}} 속성이 해당 하위 트리로만 범위가 지정된 새 카운터를 만들 수 있습니다.</p>

<div class="blockIndicator note">
<p><strong>주의</strong>: <code>style</code> containment 는 사양에서 "at-risk" 이며, 모든 곳에서 지원하지 않을 수 있습니다(현재 파이어폭스는 지원하지 않음).</p>
</div>

<h3 id="Special_values">Special values</h3>

<p>contain 에는 두 가지 특수한 값이 있습니다.</p>

<ul>
 <li><code>content</code></li>
 <li><code>strict</code></li>
</ul>

<p>위의 예에서 첫 번째를 만났습니다. <code>contain: content</code> 는 <code>layout</code> 과 <code>paint</code> containment를 모두 활성화합니다. 사양에서는 이 값을 "광범위하게 적용하기에 합리적으로 안전" 하다고 설명합니다. <code>size</code> containment 를 적용하지 않으므로 자식의 크기에 의존하고, 때문에 박스 크기가 0이 될 위험이 없습니다.</p>

<p>가능한 많은 containment 를 얻으려면 <code>contain: strict</code> 를 사용할 수 있습니다. 이는 <code>contain: size layout paint</code> 와 같습니다. 또는 <code>style</code> containment 를 지원하는 브라우저에서는 다음과 같이 사용할 수 있습니다.</p>

<pre class="brush: css notranslate">contain: strict;
contain: strict style;</pre>

<h2 id="Reference">Reference</h2>

<h3 id="CSS_Properties">CSS Properties</h3>

<ul>
 <li>{{cssxref("contain")}}</li>
</ul>

<h2 id="External_resources">External resources</h2>

<ul>
 <li><a href="https://blogs.igalia.com/mrego/2019/01/11/an-introduction-to-css-containment/">An Introduction to CSS Containment</a></li>
 <li><a href="https://dev.opera.com/articles/css-will-change-property">Everything You Need to Know About the CSS <code>will-change</code> Property</a></li>
</ul>