Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[zh-cn]: update the translation of HTMLSlotElement introduction #25217

Merged
merged 5 commits into from
Jan 10, 2025
Merged
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
53 changes: 46 additions & 7 deletions files/zh-cn/web/api/htmlslotelement/index.md
Original file line number Diff line number Diff line change
@@ -1,26 +1,65 @@
---
title: HTMLSlotElement
slug: Web/API/HTMLSlotElement
l10n:
sourceCommit: 9d5c9fbe387ba7c143fdd7c73a265b209b7f6ec4
---

{{SeeCompatTable}}{{APIRef('Web Components')}}
{{APIRef('Web Components')}}

[Shadow DOM API](/zh-CN/docs/Web/API/Web_components/Shadow_DOM) 的接口 HTMLSlotElement 使其能够访问到 HTML 元素 \<slot> 的名字和分配的节点
通过[影子 DOM API](/zh-CN/docs/Web/API/Web_components/Using_shadow_DOM) 的 **`HTMLSlotElement`** 接口,可以访问 HTML `<slot>` 元素的名称和指定节点。
T34-active marked this conversation as resolved.
Show resolved Hide resolved

## 属性
{{InheritanceDiagram}}

## 实例属性

_继承了其父接口 {{domxref("HTMLElement")}} 的属性。_
T34-active marked this conversation as resolved.
Show resolved Hide resolved

- {{domxref('HTMLSlotElement.name')}}
- : {{domxref("DOMString")}}: 可以用来设置和获取 slot 的名字
- : 用于获取和设置插槽的名称的字符串。

## 实例方法

## 方法
_继承了其父接口 {{domxref("HTMLElement")}} 的方法。_
T34-active marked this conversation as resolved.
Show resolved Hide resolved

- {{domxref('HTMLSlotElement.assign()')}}
- : 将此插槽的手动分配节点设置为给定的节点。
- {{domxref('HTMLSlotElement.assignedNodes()')}}
- : Returns the sequence of elements assigned to this slot, or alternatively the slot's fallback content.
- : 返回分配给该插槽的节点序列。如果 `flatten` 选项设置为 `true`,它将返回包含分配给该插槽的节点的一个序列,以及分配给该插槽的任何后代插槽的节点。如果没有找到分配的节点,它将返回插槽的回退内容。
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

这段话翻译得对吗,“both”是和什么连用的

T34-active marked this conversation as resolved.
Show resolved Hide resolved
- {{domxref('HTMLSlotElement.assignedElements()')}}
- : 返回分配给该插槽的元素序列(且不包括其他节点)。如果 `flatten` 选项设置为 `true`,则返回分配给该插槽的元素序列,以及分配给该插槽所有后代插槽的元素序列。如果未找到分配的元素,则返回插槽的回退内容。
yin1999 marked this conversation as resolved.
Show resolved Hide resolved

## 事件

_继承了其父接口 {{domxref("HTMLElement")}} 的事件。_
T34-active marked this conversation as resolved.
Show resolved Hide resolved

使用 {{DOMxRef("EventTarget.addEventListener", "addEventListener()")}} 监听这些事件,或通过将事件监听器分配给该接口的 `oneventname` 属性来监听。
T34-active marked this conversation as resolved.
Show resolved Hide resolved

- {{domxref('HTMLSlotElement.slotchange_event', 'slotchange')}}
- : 当插槽中包含的节点发生变化时,在 `HTMLSlotElement` 实例([`<slot>`](/zh-CN/docs/Web/HTML/Element/slot) 元素)上触发此事件。

## 示例

以下代码片段来自我们的 [slotchange 示例](https://github.com/mdn/web-components-examples/tree/main/slotchange)([也可以在线查看](https://mdn.github.io/web-components-examples/slotchange/))。

```js
let slots = this.shadowRoot.querySelectorAll("slot");
slots[1].addEventListener("slotchange", (e) => {
let nodes = slots[1].assignedNodes();
console.log(
`插槽 "${slots[1].name}" 中的元素已更改为 "${nodes[0].outerHTML}"。`,
T34-active marked this conversation as resolved.
Show resolved Hide resolved
);
});
```

在这里,我们获取所有插槽的引用,然后为模板中的第二个插槽添加一个 slotchange 事件监听器——这个插槽在示例中不断更改其内容。

每次插入到插槽中的元素发生变化时,我们会在控制台记录一条报告,指出哪个插槽发生了变化,以及插槽内的新节点是什么。

## 规范

{{Specifications}}

## 浏览器的兼容性
## 浏览器兼容性

{{Compat}}
Loading