gpt4 book ai didi

javascript - webcomponent 中的子元素

转载 作者:数据小太阳 更新时间:2023-10-29 05:11:41 25 4
gpt4 key购买 nike

假设我们有一个自定义元素以这种方式使用:

<list-image>
<img src="" />
....
</list-image>

其中list-image以 slider 方式显示img标签。如果组件的用户插入带有

的 img 标签
document.querySelector('list-image').insertAdjacentHTML('beforeend', '<img src="..." />');

组件是否有可能知道新元素img?

最佳答案

解决方案是使用 MutationObserver<list-image> 上自定义元素本身。

connectedCallback()方法,观察子元素的变化:

customElements.define('list-image', class extends HTMLElement {
connectedCallback() {
var observer = new MutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
//Detect <img> insertion
if (mutation.addedNodes.length)
console.info('Node added: ', mutation.addedNodes[0])
})
})

observer.observe(this, { childList: true })
}
})

function add() {
document.querySelector('list-image')
.insertAdjacentHTML('beforeend', '<img alt="TOTO" />')
}
<list-image>
<img alt="Image1">
<img alt="Image2">
</list-image>
<button onclick="add()">Add image</button>

关于javascript - webcomponent 中的子元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43005507/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com