From 39f8c82dad036e0be1bd8479c77b4c15612283ae Mon Sep 17 00:00:00 2001 From: Vincent Jarvis <42174702+mind-dance@users.noreply.github.com> Date: Wed, 29 Nov 2023 10:28:32 +0800 Subject: [PATCH 01/17] zh-cn: update the translation of the `` element (#17173) Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: A1lo --- files/zh-cn/web/html/element/em/index.md | 111 +++++++++++++++++------ 1 file changed, 84 insertions(+), 27 deletions(-) diff --git a/files/zh-cn/web/html/element/em/index.md b/files/zh-cn/web/html/element/em/index.md index a3e7d12cb8a4c1..9c4c5cad6ac93e 100644 --- a/files/zh-cn/web/html/element/em/index.md +++ b/files/zh-cn/web/html/element/em/index.md @@ -1,39 +1,21 @@ --- -title: +title: :强调元素 slug: Web/HTML/Element/em --- -## 简介 - -**HTML 着重元素** (**``**) 标记出需要用户着重阅读的内容, `` 元素是可以嵌套的,嵌套层次越深,则其包含的内容被认定为越需要着重阅读。 +{{HTMLSidebar}} -> **备注:** 通常地,该元素会被浏览器展示为斜体文本,但是,它不应该仅仅用于应用斜体样式;为此目的,请使用 CSS 样式。使用 {{HTMLElement("cite")}} 元素标记作品的标题(书籍,戏剧,歌曲等);它通常也采用斜体样式,但具有不同的含义。使用 {{HTMLElement("strong")}} 元素标记比周围文本更重要的文本。 +[HTML](/zh-CN/docs/Web/HTML) **``** 元素将文本标记为强调(emphasis)格式。`` 元素可以嵌套,嵌套层次越深,则强调的程度越深。 -- _内容类别_ - 流内容,推辞内容,可触及内容 -- _Permitted content_ [Phrasing content](/zh-CN/docs/Web/HTML/Content_categories#Phrasing_content). -- _Tag omission_ {{no_tag_omission}} -- _Permitted parent elements_ Any element that accepts [phrasing content](/zh-CN/docs/Web/HTML/Content_categories#Phrasing_content). -- _DOM interface_ {{domxref("HTMLElement")}} Up to Gecko 1.9.2 (Firefox 4) inclusive, Firefox implements the {{domxref("HTMLSpanElement")}} interface for this element. +{{EmbedInteractiveExample("pages/tabbed/em.html", "tabbed-shorter")}} ## 属性 此元素只包括[全局属性](/zh-CN/docs/Web/HTML/Global_attributes)。 -## 示例 - -`` 元素通常被用于指示一个隐式或显式的对比。 - -```html -

- In HTML 5, what was previously called block-level content is now - called flow content. -

-``` - -### 结果 +## 使用说明 -In HTML 5, what was previously called _block-level_ content is now called _flow_ content. +通常地,该元素会被浏览器展示为斜体文本,但是,它不应该仅仅用于应用斜体样式;为此目的,请使用 CSS {{cssxref("font-style")}} 样式。使用 {{HTMLElement("cite")}} 元素标记作品的标题(书籍、戏剧、歌曲等);它通常也采用斜体样式,但具有不同的含义。使用 {{HTMLElement("strong")}} 元素标记比周围文本更重要的文本。 ## \ vs. \ @@ -47,6 +29,83 @@ In HTML 5, what was previously called _block-level_ content is now called _flow_ 一个 `` 的例子可能是:"The _Queen Mary_ sailed last night"。在这里,没有对 "Queen Mary" 这个词添加强调或重要性。它只是表明,谈论的对象不是一个名叫玛丽的女王,而是一艘名字叫玛丽的船。另一个 `` 的例子可能是:"The word _the_ is an article"。 +## 示例 + +在此示例中,`` 元素用于突出显示两个成分列表之间的隐式或显式的对比。 + +```html +

+ 冰淇淋是用牛奶、甜味剂和奶油制成的。而冷冻蛋奶冻则由牛奶、奶油、甜味剂和蛋黄制成。 +

+``` + +### 结果 + +{{EmbedLiveSample("示例")}} + +## 技术概要 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ 内容类别 + + 流式内容短语内容和可感知内容。 +
允许的内容 + 短语内容。 +
标签省略{{no_tag_omission}}
允许的父元素 + 任何接受短语内容的元素。 +
隐式 ARIA 角色 + emphasis +
允许的 ARIA 角色任何角色
DOM 接口 + {{domxref("HTMLElement")}}。Firefox 在直至但不包含 Gecko 1.9.2(Firefox 4)的版本中为这个元素实现了 + {{domxref("HTMLSpanElement")}} 接口。 +
+ ## 规范 {{Specifications}} @@ -55,8 +114,6 @@ In HTML 5, what was previously called _block-level_ content is now called _flow_ {{Compat}} -## 了解更多 +## 参见 - {{HTMLElement("i")}} - -{{HTMLSidebar}} From 8e361ace4a146cedbfbf51f5e2a60a0737973e87 Mon Sep 17 00:00:00 2001 From: Jason Ren <40999116+jasonren0403@users.noreply.github.com> Date: Wed, 29 Nov 2023 10:30:41 +0800 Subject: [PATCH 02/17] [zh-cn] update map element of HTML (#17176) Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: A1lo --- files/zh-cn/web/html/element/map/index.md | 117 +++++++++++++--------- 1 file changed, 72 insertions(+), 45 deletions(-) diff --git a/files/zh-cn/web/html/element/map/index.md b/files/zh-cn/web/html/element/map/index.md index 39810de3b08c48..3d1e55f9516669 100644 --- a/files/zh-cn/web/html/element/map/index.md +++ b/files/zh-cn/web/html/element/map/index.md @@ -1,66 +1,95 @@ --- -title: +title: :图像映射元素 slug: Web/HTML/Element/map +l10n: + sourceCommit: 942a529383ee7ee3996fb234187641c08935f3ff --- -> **备注:** 这篇文章翻译不完整 +{{HTMLSidebar}} -**HTML `` 属性** 与 {{HTMLElement("area")}} 属性一起使用来定义一个图像映射 (一个可点击的链接区域). +[HTML](/zh-CN/docs/Web/HTML) **``** 元素与 {{HTMLElement("area")}} 元素一起使用来定义一个图像映射(一个可点击的链接区域)。 - - - - - - - - - - - - - - - - - - - - - - - -
内容类别流式内容短语内容,palpable 内容。
允许的内容任何透明元素。
标签省略{{no_tag_omission}}
允许的父元素任何接受短语内容的元素。
DOM 接口{{domxref("HTMLMapElement")}}
+{{EmbedInteractiveExample("pages/tabbed/map.html", "tabbed-standard")}} ## 属性 -这个元素拥有[全局属性](/zh-CN/docs/HTML/Global_attributes)。 +这个元素包含[全局属性](/zh-CN/docs/Web/HTML/Global_attributes)。 - `name` - - : name 属性 给 map 一个名字用来查询,这个属性是必须的,值必须不能为空并且不能带空格。name 属性不准与同文档中其他 map 元素的值相同,如果 id 属性也被添加,name 属性和 id 属性的值必须相同。 + - : `name` 属性给予该映射引用的名称,这个属性必须存在,值不得为空并且不能带空格。`name` 属性的值不得与同文档中其他 `` 元素的该属性值相同,如果还指定了 [`id`](/zh-CN/docs/Web/HTML/Global_attributes#id) 属性,则两个属性的值必须相同。 ## 示例 +### 含有两个区域的图像映射 + +单击左侧的鹦鹉访问 JavaScript 页面,单击右侧的鹦鹉访问 CSS 页面。 + +#### HTML + ```html - - - + + + JavaScript + CSS +两只鹦鹉的照片,大小为 350 x 150 ``` -### 结果 +#### 结果 -{{ EmbedLiveSample('示例', '350', '166') }} +{{ EmbedLiveSample('含有两个区域的图像映射', '', '250') }} -### Expected live example output +## 技术概要 -The live example above should appear similar to the following images (when using your keyboard tab key): - -_For the `left.html` link:_ -![](screen_shot_2017-02-02_at_10.48.40_pm.png) - -_For the `right.html` link_ -![](screen_shot_2017-02-02_at_10.49.04_pm.png) + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
内容类别流式内容短语内容、可感知内容。
允许的内容任何透明元素。
标签省略{{no_tag_omission}}
允许的父元素任何接受短语内容的元素。
隐式 ARIA 角色 + 没有相应的角色 +
允许的 ARIA 角色没有允许的 role
DOM 接口{{domxref("HTMLMapElement")}}
## 规范 @@ -70,9 +99,7 @@ _For the `right.html` link_ {{Compat}} -## 另见 +## 参见 - {{HTMLElement("a")}} - {{HTMLElement("area")}} - -{{HTMLSidebar}} From 5127d28e4349306727a391c0c75a51e01173bc20 Mon Sep 17 00:00:00 2001 From: Dayeon Yoon <88532969+YDayeon@users.noreply.github.com> Date: Wed, 29 Nov 2023 13:12:14 +0900 Subject: [PATCH 03/17] [ko] translate intersection_observer_api (#16733) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * [ko] translate intersection_observer_api * fix error * hash 추가 및 매크로 공백 수정 * Update files/ko/web/api/intersection_observer_api/index.md Co-authored-by: hochan Lee * Update files/ko/web/api/intersection_observer_api/index.md Co-authored-by: hochan Lee * Update files/ko/web/api/intersection_observer_api/index.md Co-authored-by: hochan Lee * Update files/ko/web/api/intersection_observer_api/index.md Co-authored-by: hochan Lee * Update files/ko/web/api/intersection_observer_api/index.md Co-authored-by: hochan Lee * Update files/ko/web/api/intersection_observer_api/index.md Co-authored-by: hochan Lee * 제안 내용 반영 * Update files/ko/web/api/intersection_observer_api/index.md Co-authored-by: hochan Lee * 역치 값 띄어쓰기 통일 * 업데이트를 갱신으로 텍스트 변경 * 제목 번역 및 역치 값을 임계값 텍스트로 통일 --------- Co-authored-by: hochan Lee --- .../api/intersection_observer_api/index.md | 611 ++++++++++++++++++ 1 file changed, 611 insertions(+) create mode 100644 files/ko/web/api/intersection_observer_api/index.md diff --git a/files/ko/web/api/intersection_observer_api/index.md b/files/ko/web/api/intersection_observer_api/index.md new file mode 100644 index 00000000000000..4fc6c0a9736a3d --- /dev/null +++ b/files/ko/web/api/intersection_observer_api/index.md @@ -0,0 +1,611 @@ +--- +title: Intersection Observer API +slug: Web/API/Intersection_Observer_API +l10n: + sourceCommit: 6f0b1e294dc3aa8d6423df8aae059081a3464676 +--- + +{{DefaultAPISidebar("Intersection Observer API")}} + +Intersection Observer API는 상위 요소 또는 최상위 문서의 {{Glossary("viewport")}}와 대상 요소 사이의 변화를 비동기적으로 관찰할 수 있는 수단을 제공합니다. + +역사적으로, 요소의 가시성 또는 관련된 두 요소 사이의 상대적 가시성을 감지하는 것은 해결책을 신뢰할 수 없고 브라우저와 사용자가 접근하는 사이트를 느리게 만드는 어려운 작업이었습니다. Web이 성숙해짐에 따라, 이러한 종류의 정보의 요구가 늘어났습니다. 교차 정보는 다음과 같은 많은 이유로 필요합니다. + +- 페이지가 스크롤 될 때 이미지의 또는 다른 컨텐츠의 지연 로딩(Lazy-loading) 됩니다. +- 스크롤할 때 더 많은 컨텐츠가 로드되고 렌더링 되는 "무한 스크롤" 웹 사이트를 구현함으로써, 사용자가 페이지를 넘길 필요가 없습니다. +- 광고 수익 산정을 위해 광고 가시성을 보고합니다. +- 사용자가 결과를 볼 수 있을지 여부에 따라 작업 또는 애니메이션 프로세스를 수행할지 여부를 결정합니다. + +과거에 교차 감지 구현은 영향을 받는 모든 요소에 대해 필요한 정보를 축적하기 위해 이벤트 처리기와 {{domxref("Element.getBoundingClientRect()")}}와 같은 메서드를 호출하는 루프를 포함하였습니다. 모든 코드가 메인 스레드에서 실행되기 때문에, 이 중 하나라도 성능 문제를 일으킬 수 있습니다. 이러한 테스트와 함께 사이트가 로드 될 때, 완전히 못생겨질 수 있었습니다. + +무한 스크롤을 사용하는 웹 페이지를 생각해봅시다. 주기적으로 페이지에 배치되는 광고를 관리하기 위해 공급업체가 제공하는 라이브러리를 사용하고, 여기저기에 애니메이션 그래픽이 있으며, 공지 박스 같은 것들을 그리는 사용자 정의 라이브러리도 사용합니다. 이 각각에는 해당 교차 감지 루틴이 있고 모두 메인 스레드에서 실행됩니다. 웹 사이트 제작자는 그들이 사용하는 두 가지 라이브러리에 들어있는 내부 작업에 대해서 조금만 알기 때문에 이러한 일이 일어나는 지도 깨닫지 못할 것입니다. 유저가 페이지를 스크롤 할 때, 이러한 교차 감지 루틴은 스크롤 처리 코드가 실행되는 동안 지속적으로 발생하여 사용자가 브라우저, 웹사이트, 컴퓨터에 불만을 느끼게 합니다. + +Intersection Observer API는 특정 요소가 다른 요소(또는 {{Glossary("viewport")}})와의 교차점에 들어가거나 나갈 때 또는 두 요소 간의 교차점이 지정된 양만큼 변화될 때 실행되는 콜백 함수를 코드에 등록할 수 있습니다. 이 방법으로, 사이트는 더이상 이러한 종류의 요소 교차를 감시하기 위해 메인 스레드에 아무것도 할 필요가 없고, 브라우저는 적합하다고 판단되는 대로 교차 관리를 자유롭게 최적화할 수 있습니다. + +Intersection Observer API가 알려주지 않는 한 가지: 겹치는 픽셀의 정확한 수나 구체적으로 어떤 픽셀인지를 알려주지 못합니다. 그러나 이 API는 "약 N% 정도 겹친다면 어떤 작업을 수행해야 한다"는 더 일반적인 사용 사례를 다룹니다. + +## 교차 관찰자 개념과 사용 + +Intersection Observer API는 다음과 같은 상황이 발생했을 때 호출되는 콜백 함수를 구성할 수 있습니다. + +- **대상** 요소는 기기의 뷰포트 또는 특정 요소와 교차합니다. 특정 요소는 Intersection Observer API의 목적에 따라 **루트 요소** 또는 **루트**라고 불립니다. +- observer가 최초로 대상 요소를 관찰하라고 요청 받은 시점입니다. + +일반적으로, 대상 요소와 가장 가까운 스크롤 가능한 상위 요소나 타겟요소가 스크롤 가능한 요소의 하위 요소가 아닌 경우, 장치 뷰포트와 관련된 교차 변화를 관찰하고 싶어합니다. 장치 뷰포트와 관련된 교차를 관찰하기 위해서는 `root` 옵션에 `null`을 지정해야 합니다. 교차 관찰자 옵션에 대한 더 자세한 설명을 위해서 계속 읽어야 합니다. + +뷰포트를 루트로 사용하던지 다른 요소들을 루트로 사용하던지, API는 같은 방식으로 동작하여 대상 요소의 가시성이 변화하여 요청한 양만큼 루트와 교차할 때마다 사용자가 제공한 콜백함수를 실행합니다. + +타겟 요소와 타겟 요소의 루트 사이의 교차의 정도는 **intersection ratio** 입니다. 0.0과 1.0 사이의 값으로 보이는 대상 요소의 백분율을 나타냅니다. + +### 교차 관찰자 생성하기 + +intersection observer는 생성자를 호출하고, threshold가 한 방향 혹은 다른 방향으로 교차할 때마다 실행하기 위한 callback 함수를 전달하여 생성합니다. + +```js +let options = { + root: document.querySelector("#scrollArea"), + rootMargin: "0px", + threshold: 1.0, +}; + +let observer = new IntersectionObserver(callback, options); +``` + +threshold가 1.0이라는 의미는 `root` 옵션으로 지정된 요소 내에서 타겟 요소가 100% 보이면 콜백이 호출된다는 의미입니다. 다음과 같은 필드가 있습니다. + +#### 교차 관찰자 옵션 + +{{domxref("IntersectionObserver.IntersectionObserver", "IntersectionObserver()")}} 생성자에 전달되는 `options` 객체는 observer의 콜백이 언제 호출되는지를 제어할 수 있게 해줍니다. 이 객체는 다음과 같은 필드를 가지고 있습니다. + +- `root` + - : 대상 가시성을 체크하기 위한 뷰포트로 사용되는 요소. 반드시 타겟의 상위 요소이어야 합니다. 만약 뷰포트를 지정하지 않거나 `null` 이면 브라우저 뷰포트가 기본으로 설정됩니다. +- `rootMargin` + - : 루트 주위의 여백입니다. CSS {{cssxref("margin")}} 속성과 비슷한 값을 가질 수 있습니다. 예시. `"10px 20px 30px 40px"` (위, 오른쪽, 아래, 왼쪽). 값은 백분율이 될 수 있습니다. 이 값의 집합은 교차 지점을 계산하기 전에 루트 요소 경계 박스의 각 사이드 값을 늘리거나 줄일 수 있습니다. 기본 값은 0입니다. +- `threshold` + - : 관찰자의 콜백이 무조건 실행되어야 하는 대상의 가시성 백분율을 나타내는 숫자 또는 숫자 배열입니다. 만약 가시성이 50% 지점을 넘는 경우만 감지하고 싶다면, 0.5를 지정하여 사용할 수 있습니다. 만약 가시성이 25%만큼 넘어갈 때마다 콜백을 실행하고 싶다면, \[0, 0.25, 0.5, 0.75, 1]을 지정하여 사용할 수 있습니다. 기본 값은 0 입니다. (1 픽셀이라도 보이면, 콜백이 실행됩니다.) 1.0의 값은 모든 픽셀이 가시 상태가 될 때까지 임계값이 통과되지 않는다는 것을 의미합니다. + +#### 관찰할 요소를 대상으로 하기 + +관찰자를 생성했다면, 관찰할 타겟 요소를 전달해야 합니다. + +```js +let target = document.querySelector("#listItem"); +observer.observe(target); + +// observer를 위해 설정한 콜백은 바로 지금 최초로 실행됩니다 +// 대상을 관찰자에 할당할 때까지 기다립니다. (타겟이 현재 보이지 않더라도) +``` + +언제든지 타겟 요소가 `IntersectionObserver`에 지정된 임계값을 만족시키면, 콜백은 호출됩니다. 콜백은 {{domxref("IntersectionObserverEntry")}} 객체와 관찰자 목록을 받습니다. + +```js +let callback = (entries, observer) => { + entries.forEach((entry) => { + // 각 엔트리는 관찰된 하나의 교차 변화을 설명합니다. + // 대상 요소: + // entry.boundingClientRect + // entry.intersectionRatio + // entry.intersectionRect + // entry.isIntersecting + // entry.rootBounds + // entry.target + // entry.time + }); +}; +``` + +콜백이 수신한 엔트리 목록은 교차 상태의 변화를 보고한 각 대상에 대한 하나의 엔트리를 포함합니다. 엔트리가 현재 루트와 교차하는 요소를 나타내는지 보기 위해 {{domxref("IntersectionObserverEntry.isIntersecting", "isIntersecting")}} 속성 값을 확인합니다. + +콜백이 메인스레드에서 실행되는 것을 유의해야 합니다. 가능한 한 최대한 빨리 동작해야 합니다. 만약 시간 소비가 필요한 일이 마무리 되어야 한다면, {{domxref("Window.requestIdleCallback()")}}을 사용하세요. + +또한, `root` 옵션을 지정했다면, 대상은 반드시 루트 요소의 하위 요소이어야만 한다는 점을 명심해야 합니다. + +### 교차 계산 방법 + +Intersection Observer API가 고려하는 모든 영역은 직사각형입니다. 불규칙한 모양의 요소는 모든 요소를 둘러싸는 부분들을 가장 작은 직사각형이 차지하는 것으로 여겨집니다. 비슷하게, 요소의 보이는 부분이 직사각형이 아니면, 요소의 교차하는 직사각형이 요소의 보이는 모든 부분을 포함하는 가장 작은 직사각형으로 간주됩니다. + +{{domxref("IntersectionObserverEntry")}}에서 제공하는 다양한 속성이 교차를 어떻게 설명하는지를 조금 이해하는 것이 유용합니다. + +#### 교차 루트와 루트 여백 + +컨테이너와 요소의 교차를 따라가기 전에, 우리는 컨테이너가 무엇인지를 알아야 합니다. 컨테이너는 **교차 루트** 또는 **루트 요소** 입니다. 관찰 대상 요소의 상위 요소인 document의 특정 요소이거나 컨테이너로 문서 뷰포트를 사용하기 위한 `null`이 될 수 있습니다. + +**루트 교차 직사각형**은 대상 요소를 확인하기 위한 직사각형입니다. 이 직사각형은 다음과 같이 결정됩니다. + +- 만약 교차 루트가 절대적인 루트라면(즉, 최상단 {{domxref("Document")}}), 루트 교차 직사각형은 뷰포트 직사각형입니다. +- 교차 루트에 overflow clip이 있는 경우, 루트 교차 직사각형은 루트 요소의 컨텐츠 영역입니다. +- 위 두 가지 경우가 아니라면, root 교차 직사각형은 교차 루트 경계 클라이언트 직사각형입니다.({{domxref("Element.getBoundingClientRect", "getBoundingClientRect()")}}를 호출하여 반환된) + +루트 교차 직사각형은 {{domxref("IntersectionObserver")}}를 생성할 때, **root margin** , `rootMargin`을 설정함으로 인해 조정될 수 있습니다. `rootMargin` 값은 최종 교차 루트 경계 (콜백이 실행될 때 {{domxref("IntersectionObserverEntry.rootBounds")}}에 공개된)를 생성하기 위해 교차 루트 경계 박스의 각 측면을 더해 오프셋을 정의합니다. + +#### Thresholds + +매번 대상 요소가 얼마나 보이는지의 극미한 변화마다 보고하는 것보다 Intersection Observer API는 **thresholds** 를 사용합니다. 관찰자를 생성할 때, 하나 또는 하나 이상의 보이는 대상 요소의 백분율을 나타내는 숫자 값을 제공할 수 있습니다. 그런 다음, API는 이러한 임계값을 넘어가는 가시성 변경 사항만 보고합니다. + +예를 들어, 대상의 가시성이 각 25% 지점보다 크거나 작을 때마다 보고를 받고 싶다면, 관찰자를 생성할 때 \[0, 0.25, 0.5, 0.75, 1]로 이루어진 임계값 목록을 지정해야 합니다. + +콜백이 호출될 때, 어느 방향에서든 노출된 양이 임계값 중 하나를 초과하는 루트 변화를 교차하는 정도가 관찰된 각 대상에 대한 `IntersectionObserverEntry` 객체 목록을 받습니다. + +엔트리의 {{domxref("IntersectionObserverEntry.isIntersecting", "isIntersecting")}} 속성을 관찰함으로써 대상이 현재 루트를 교차하는 것을 볼 수 있습니다. 만약 해당 값이 `true` 라면, 대상은 최소한 부분적으로 루트 요소나 문서와 교차하고 있습니다. 이를 통해 엔트리는 교차하는 요소에서 더 이상 교차하지 않는 요소로의 전환을 나타내거나 교차하지 않음에서 교차하는 전환으로 나타낼 수 있습니다. + +교차가 정확이 두 개 사이의 경계 또는 {{domxref("IntersectionObserverEntry.boundingClientRect", "boundingClientRect")}}가 0인 영역을 따르는 경우에 발생하는 무조건 교차하는 직사각형이 존재할 수 있다는 것을 주목해야 합니다. 경계선을 공유하는 대상과 루트의 상태는 교차 상태로의 전환이 충분하지 않다고 여겨질 수 있습니다. + +어떻게 임계값이 동작하는 지를 느껴보기 위해서, 아래 상자를 스크롤 해봅시다. 그 안의 각 색칠된 상자는 네 모서리의 보이는 영역의 백분율을 보여주고, 따라서 컨테이너를 스크롤할 때 시간이 지남에 따라 이 비율이 변화하는 것을 볼 수 있습니다. 각 상자는 다른 임계값을 가지고 있습니다. + +- 첫번째 상자는 각 가시성 백분율에 대한 임계값을 가지고 있습니다. 즉, {{domxref("IntersectionObserver.thresholds")}} 목록은 `[0.00, 0.01, 0.02, /*…,*/ 0.99, 1.00]` 입니다. +- 두번째 상자는 50% 지점에 하나의 임계값을 가지고 있습니다. +- 세번째 상자는 가시성의 10% 마다 임계값을 가지고 있습니다. (0%, 10%, 20%, 등.). +- 마지막 상자는 각 25% 마다 임계값을 가지고 있습니다. + +```html hidden + + +
+
+
+
+
+``` + +```css hidden +.contents { + position: absolute; + width: 700px; + height: 1725px; +} + +.wrapper { + position: relative; + top: 600px; +} + +.sampleBox { + position: relative; + left: 175px; + width: 150px; + background-color: rgb(245, 170, 140); + border: 2px solid rgb(201, 126, 17); + padding: 4px; + margin-bottom: 6px; +} + +#box1 { + height: 200px; +} + +#box2 { + height: 75px; +} + +#box3 { + height: 150px; +} + +#box4 { + height: 100px; +} + +.label { + font: + 14px "Open Sans", + "Arial", + sans-serif; + position: absolute; + margin: 0; + background-color: rgba(255, 255, 255, 0.7); + border: 1px solid rgba(0, 0, 0, 0.7); + width: 3em; + height: 18px; + padding: 2px; + text-align: center; +} + +.topLeft { + left: 2px; + top: 2px; +} + +.topRight { + right: 2px; + top: 2px; +} + +.bottomLeft { + bottom: 2px; + left: 2px; +} + +.bottomRight { + bottom: 2px; + right: 2px; +} +``` + +```js hidden +let observers = []; + +startup = () => { + let wrapper = document.querySelector(".wrapper"); + + // 관찰자를 위한 옵션 + + let observerOptions = { + root: null, + rootMargin: "0px", + threshold: [], + }; + + // An array of threshold sets for each of the boxes. The + // first box's thresholds are set programmatically + // since there will be so many of them (for each percentage + // point). + + let thresholdSets = [ + [], + [0.5], + [0.0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0], + [0, 0.25, 0.5, 0.75, 1.0], + ]; + + for (let i = 0; i <= 1.0; i += 0.01) { + thresholdSets[0].push(i); + } + + // Add each box, creating a new observer for each + + for (let i = 0; i < 4; i++) { + let template = document + .querySelector("#boxTemplate") + .content.cloneNode(true); + let boxID = `box${i + 1}`; + template.querySelector(".sampleBox").id = boxID; + wrapper.appendChild(document.importNode(template, true)); + + // Set up the observer for this box + + observerOptions.threshold = thresholdSets[i]; + observers[i] = new IntersectionObserver( + intersectionCallback, + observerOptions, + ); + observers[i].observe(document.querySelector(`#${boxID}`)); + } + + // Scroll to the starting position + + document.scrollingElement.scrollTop = + wrapper.firstElementChild.getBoundingClientRect().top + window.scrollY; + document.scrollingElement.scrollLeft = 750; +}; + +intersectionCallback = (entries) => { + entries.forEach((entry) => { + let box = entry.target; + let visiblePct = `${Math.floor(entry.intersectionRatio * 100)}%`; + + box.querySelector(".topLeft").innerHTML = visiblePct; + box.querySelector(".topRight").innerHTML = visiblePct; + box.querySelector(".bottomLeft").innerHTML = visiblePct; + box.querySelector(".bottomRight").innerHTML = visiblePct; + }); +}; + +startup(); +``` + +{{EmbedLiveSample("Thresholds", 500, 500)}} + +#### 잘라내기와 교차 직사각형 + +브라우저는 다음과 같이 최종 교차 직사각형을 계산합니다. 교차가 일어날 때를 더 정확히 이해하기 위해서 아래 순서를 이해하는 것은 도움이 됩니다. + +1. 대상 요소의 경계 직사각형 (즉, 요소를 구성하는 모든 컴포넌트의 경계 상자를 완전히 둘러싸는 제일 작은 직사각형)은 타겟의 {{domxref("Element.getBoundingClientRect", "getBoundingClientRect()")}}로부터 얻습니다. 이건 아마 가장 큰 교차 직사각형입니다. 아래 남은 순서에서 교차 되지 않는 어떤 부분도 제거합니다. +2. 대상의 직계 상위 블록에서 시작하여 밖으로 뻗어 나가면서, 포함된 블록의 잘라낸 조각이 있는 경우 교차 직사각형에 적용됩니다. 블록의 잘라낸 조각은 두 개 블록의 교차와 {{cssxref("overflow")}} 속성에 의해 특정된 잘라내기 모드가 있다면 이를 기반으로 결정됩니다. `overflow` 를 `visible` 이 아닌 것에 설정하면 clipping이 발생할 수 있습니다. +3. 포함된 요소 중 하나가 중첩된 브라우징 컨텍스트({{HTMLElement("iframe")}}에 들어있는 문서와 같은)의 루트라면, 교차 사각형은 포함된 컨텍스트의 뷰포트에 고정되고, 컨테이너를 따라 컨테이너의 포함된 블록과 위쪽으로의 반복이 계속됩니다. `