gpt4 book ai didi

javascript - 如何停止所有事件的传播

转载 作者:行者123 更新时间:2023-11-29 16:15:09 24 4
gpt4 key购买 nike

我想知道如何在所有类型的事件到达某个元素时停止它们的传播。

我想过

function stop(e){
e.stopPropagation();
}
function stopEvents(el){
var events = ['click', 'mousemove', ...];
for(var i=0; i<events.length; ++i){
el.addEventListener(events[i], stop, false);
}
}

有没有更聪明的方法?

我的代码似乎可以工作,但我想要一个不需要所有可能事件列表的代码。

Because if I write a GreaseMonkey module which other people can use to add content to pages, I don't want events generated inside that content to trigger page's event listeners (assuming they don't use capture). Actually I solved it using iframes, but the question remains for academic purposes

最佳答案

function stop(e){
e.stopPropagation();
}
function stopEvents(el){
for(var key in window) {
if (key.indexOf("on") == 0) {
el.addEventListener(key.substr(2), stop, false);
}
}
}

这就是您获取所有事件的方式。

但这可能会导致一些问题。例如,如果您将另一个键添加到以 on 开头的 window 对象中,它也将被视为一个 “事件”

您还必须考虑到 window 对象很大。

我只会使用您的代码。完整的事件列表是:

谷歌浏览器

["deviceorientation", "transitionend", "webkittransitionend", "webkitanimationstart", "webkitanimationiteration", "webkitanimationend", "search", "reset", "waiting", "volumechange", "unload", "timeupdate", "suspend", "submit", "storage", "stalled", "select", "seeking", "seeked", "scroll", "resize", "ratechange", "progress", "popstate", "playing", "play", "pause", "pageshow", "pagehide", "online", "offline", "mousewheel", "mouseup", "mouseover", "mouseout", "mousemove", "mousedown", "message", "loadstart", "loadedmetadata", "loadeddata", "load", "keyup", "keypress", "keydown", "invalid", "input", "hashchange", "focus", "error", "ended", "emptied", "durationchange", "drop", "dragstart", "dragover", "dragleave", "dragenter", "dragend", "drag", "dblclick", "contextmenu", "click", "change", "canplaythrough", "canplay", "blur", "beforeunload", "abort"]

火狐

["SearchSubmit", "mouseenter", "mouseleave", "afterprint", "beforeprint", "beforeunload", "hashchange", "message", "offline", "online", "popstate", "pagehide", "pageshow", "resize", "unload", "devicemotion", "deviceorientation", "deviceproximity", "userproximity", "devicelight", "abort", "blur", "canplay", "canplaythrough", "change", "click", "contextmenu", "dblclick", "drag", "dragend", "dragenter", "dragleave", "dragover", "dragstart", "drop", "durationchange", "emptied", "ended", "error", "focus", "input", "invalid", "keydown", "keypress", "keyup", "load", "loadeddata", "loadedmetadata", "loadstart", "mousedown", "mousemove", "mouseout", "mouseover", "mouseup", "mozfullscreenchange", "mozfullscreenerror", "mozpointerlockchange", "mozpointerlockerror", "pause", "play", "playing", "progress", "ratechange", "reset", "scroll", "seeked", "seeking", "select", "show", "stalled", "submit", "suspend", "timeupdate", "volumechange", "waiting", "wheel", "copy", "cut", "paste", "beforescriptexecute", "afterscriptexecute"]

关于javascript - 如何停止所有事件的传播,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17645014/

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