我添加了一个事件监听器来捕获用户操作后加载SVG。
HTML
<object id="mySVG" type="image/svg+xml" data="default.svg"></object>
JS
mySVG = document.getElementById('mySVG');
mySVG.addEventListener('load', function () {
// work with SVG contentDocument
});
mySVG.setAttribute('data', 'new.svg');
在另一个用户操作之后,我通过加载空白内联SVG来清除SVG
var svgUrl = URL.createObjectURL(new Blob(['<svg xmlns="http://www.w3.org/2000/svg" width="700" height="700"/>'], {'type':'image/svg+xml'}));
mySVG.setAttribute('data', svgUrl);
我看起来像设置这个空白的SVG也触发了加载事件,这是不可取的。所以我试过了
mySVG.removeEventListener('load');
这给了我错误
TypeError:没有足够的EventTarget.removeEventListener参数。
在此上下文中removeEventListener的正确语法是什么?
编辑:设置空白SVG的方法不正确,读完this后更正。
您应该命名您的函数,然后将其作为第二个参数传递给addEventListener
和removeEventListener
,如下所示:
mySVG = document.getElementById('mySVG');
function loadFunction() {
// work with SVG contentDocument
}
mySVG.addEventListener('load', loadFunction);
mySVG.setAttribute('data', 'new.svg');
mySVG.setAttribute('data', 'data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22700%22%20height%3D%22700%22%2F%3E');
mySVG.removeEventListener('load', loadFunction);
<object id="mySVG" type="image/svg+xml" data="default.svg"></object>
removeEventListener
至少需要两个参数,即事件类型('load'
)和要删除的侦听器,因此您必须引用先前为其删除的侦听器。
mySVG.removeEventListener( '负载');应该有一个目标作为侦听事件的第二个参数