首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何观察HTMLCollection?

如何观察HTMLCollection?
EN

Stack Overflow用户
提问于 2021-06-12 11:07:55
回答 1查看 236关注 0票数 4

我有点好奇,因为我知道HTMLCollections会自动更新自己,所以我尝试使用代理来观察它们,如下所示

代码语言:javascript
复制
let imagesCollection = document.images;

let io = new Proxy(imagesCollection, {
    set: (target, prop, value, reciever) => {
        // do stuff
        // apply default behaviour
        return Reflect.set(target, prop, value);
    }
});

// test the block by adding new elements

document.body.insertAdjacentHTML("beforeend", "<img>");
document.body.insertAdjacentHTML("beforeend", "<img class='img'>");
document.body.insertAdjacentHTML(
    "beforeend",
    "<img class='img' src='https://picsum.photos/200/300'>"
);

但是当试图动态添加一些图像时,什么都不会发生.

所以我的问题是:

  • 这可能吗?
  • 如果是,我是不是做错了?
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-06-12 12:32:35

如果我正确理解,代理会用代理来拦截操作,而不是使用目标:

代码语言:javascript
复制
let target = {};

let proxy = new Proxy(target, {
    set: (target, prop, value, reciever) => {
        console.log(prop, value);
        return Reflect.set(target, prop, value);
    }
});

target.foo = 'I am not intercepted.';
proxy.bar = 'I am intercepted.';

因此,在您的示例中,使用io的操作将被拦截,而使用imagesCollectiondocument.images的操作则不会被截获。

所以变异观察者是一个更好的选择。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67948240

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档