From e1982fb00f0b620e71233e07d9f3b98fc2164564 Mon Sep 17 00:00:00 2001 From: Vivi Date: Mon, 29 Jul 2024 08:07:47 +0900 Subject: [PATCH] =?UTF-8?q?[ko]=20css=20doublecolon=20slotted=20=EB=B2=88?= =?UTF-8?q?=EC=97=AD=20(#22311)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit feat: [ko] css doublecolon slotted 번역 --- .../ko/web/css/_doublecolon_slotted/index.md | 129 ++++++++++++++++++ 1 file changed, 129 insertions(+) create mode 100644 files/ko/web/css/_doublecolon_slotted/index.md diff --git a/files/ko/web/css/_doublecolon_slotted/index.md b/files/ko/web/css/_doublecolon_slotted/index.md new file mode 100644 index 00000000000000..dfc9ed3e6e7066 --- /dev/null +++ b/files/ko/web/css/_doublecolon_slotted/index.md @@ -0,0 +1,129 @@ +--- +title: "::slotted()" +slug: Web/CSS/::slotted +l10n: + sourceCommit: cebbd9095ac12557c55157355181672027fffc14 +--- + +{{CSSRef}} + +**`::slotted()`** [CSS](/ko/docs/Web/CSS) [의사 요소](/ko/docs/Web/CSS/Pseudo-elements)는 HTML 템플릿 내부 슬롯에 위치할 수 있는 모든 요소를 나타냅니다. (더 많은 정보는 [템플릿과 슬롯](/ko/docs/Web/API/Web_components/Using_templates_and_slots) 문서를 참고하세요.). + +이는 [shadow DOM](/ko/docs/Web/API/Web_components/Using_shadow_DOM) 내에 배치된 CSS 내에서만 동작합니다. 이 선택자는 슬롯에 배치된 텍스트 노트를 선택하지 않고, 실제 요소만을 대상으로 한다는 점을 참고하세요. + +{{EmbedInteractiveExample("pages/tabbed/pseudo-element-slotted.html", "tabbed-shorter")}} + +```css +/* 슬롯 내에 위치한 모든 요소를 선택합니다. */ +::slotted(*) { + font-weight: bold; +} + +/* 슬롯 내에 위치한 모든 을 선택합니다.*/ +::slotted(span) { + font-weight: bold; +} +``` + +## 구문 + +```css-nolint +::slotted() { + /* ... */ +} +``` + +## 예제 + +### 슬롯 요소 하이라이트 하기 + +이 예제에서는 세 개의 슬롯이 있는 템플릿을 사용합니다. + +```html + +``` + +사용자 정의 요소로 `` 를 정의합니다. 이 경우에는, JavaScript를 이용하여 스타일을 추가하지만, 같은 효과를 위해 {{HTMLElement("template", "템플릿")}} 내의 {{HTMLElement("style", "스타일")}} 블록 안에 스타일을 추가할 수도 있습니다. + +```js +customElements.define( + "person-details", + class extends HTMLElement { + constructor() { + super(); + let template = document.getElementById("person-template"); + let templateContent = template.content; + + const shadowRoot = this.attachShadow({ mode: "open" }); + + let style = document.createElement("style"); + style.textContent = + "div { padding: 10px; border: 1px solid gray; width: 200px; margin: 10px; }" + + "h2 { margin: 0 0 10px; }" + + "ul { margin: 0; }" + + "p { margin: 10px 0; }" + + "::slotted(*) { color: gray; font-family: sans-serif; } " + + "::slotted(span) {text-decoration: underline;} "; + + shadowRoot.appendChild(style); + shadowRoot.appendChild(templateContent.cloneNode(true)); + } + }, +); +``` + +`style` 요소를 콘텐츠로 채울 때는 모든 슬롯된 요소들을 선택하고 (`::slotted(*)`) 이들에게 다른 글꼴과 색상을 적용할 수 있습니다. 이 차이는 색상이 채워지지 않은 슬롯들과 구분됩니다. 여기서는 {{HTMLElement("span")}}들 (`::slotted(span)`)을 스타일링하여 ``들을 {{HTMLElement("p")}}들과 구별했습니다. + +여기서 사용된 마크업은 `