我正在尝试创建一个Proxy
对象来Image
捕获属性,但即使使用空处理程序,我也会收到一条错误消息。
TypeError:Node.appendChild 的参数 1 没有实现接口 Node。
代理对象应该充当目标对象,所以这让我有点困惑。据我了解,您也应该能够使用DOM 节点执行此操作(?)。
另外:我无法开始加载图像并在设置属性onload
时触发处理程序。src
我应该如何使用代理,以便我可以“接管”例如“src”属性,否则让它像普通图像对象一样工作?
我的代码
'use strict';
//--- normal image use ---
var imgNormal = new Image();
imgNormal.onload = function(){
console.log('Normal loaded OK');
document.body.appendChild(imgNormal);
};
imgNormal.src = 'https://i.imgur.com/zn7O7QWb.jpg';
//--- proxy image ---
var imgProxy = new Proxy(Image, { // I also tried with 'new Image()' and HTMLImageElement
set: function(a,b,c,d){
console.log('set '+b);
return Reflect.set(a,b,c,d);
}
});
imgProxy.onload = function(){
console.log('Proxy loaded OK');
document.body.appendChild(imgProxy);
};
imgProxy.src = 'https://i.imgur.com/zn7O7QWb.jpg';
document.body.appendChild(imgProxy); // double-up to demo error
更新:感谢@Harangue!使用 " 现在我无法捕获属性的设置。它似乎完全忽略了陷阱-例如:new
" (bah..) 确实使代理对象变得栩栩如生,但是
var proxy = new Proxy(Image, {
set: function(a,b,c,d){
console.log('set '+b); // doesn't show
return Reflect.set(a,b,c,d);
}
});
var imgProxy = new proxy();
imgProxy.onload = function(){
console.log('Proxy loaded OK');
document.body.appendChild(imgProxy);
};
imgProxy.src = 'https://i.imgur.com/zn7O7QWb.jpg';
如何使用有效代理捕获属性设置?
更新 2另一方面 -new
与新代理一起使用似乎只使用原始构造函数。我能找到的所有例子都没有使用新的:
var myProxy = new Proxy(.., ..); // should suffer
在此之上使用 thennew myProxy()
似乎只使用原始构造函数,这不是我想要的,因为它忽略了陷阱。
var proxy = new Proxy(Image, {}); //should be sufficent??
var proxy2 = new proxy();
console.log(proxy2); //-> says Image (not proxy..)
陷阱似乎在我的第一次尝试中起作用,但代理的行为不如预期。这太令人困惑了,太新奇了。对如何解决这两个问题(陷阱和行为)的任何输入感到高兴。