gpt4 book ai didi

javascript - 是否可以让其他 javascript 事件监听器等待异步事件?

转载 作者:行者123 更新时间:2023-11-29 21:33:27 25 4
gpt4 key购买 nike

我想劫持一个网页(使用 Tampermonkey),它有一个带有一些事件监听器的按钮,最后是一个重定向。

有没有办法将我自己的点击事件处理程序添加到按钮,发出 AJAX 请求,并在继续处理其他事件监听器之前等待它完成,所以我的 AJAX 请求肯定在重定向之前完成?

我知道 stopImmediatePropagation但不是如何异步“延迟”传播。

最佳答案

不,您不能让其他事件处理程序等待。您有时可以覆盖/劫持现有函数,但这通常无法使用 Tampermonkey 实现,并且可能会变得困惑(例如在 Firefox + Greasemonkey 中)。

对于像按钮这样的可点击元素,一种解决方法是覆盖按钮,在其上设置监听器,然后让它们在时机成熟时在原始按钮上触发所需的事件。

例如,请考虑以下代码段:

  1. #mainButton 及其代码代表原始页面。
  2. “劫持”按钮模拟 Tampermonkey 脚本的运行。
  3. “脚本”创建了一个与按钮大小相同的 div 并将其放置在按钮上方。因此,所有点击都被 div 捕获,而不是按钮。
  4. 拦截代码执行一些异步操作,然后触发对原始按钮的点击。

//--------------------------
//--- The page's code:
//--------------------------
$("#mainButton").click ( function () {
logline ("The button was clicked.");
} );

//------------------------------
//--- The script setup and code:
//------------------------------
$("#tmIntercept").click ( function () {
logline ("==> Main button is now intercepted.");
//this.disabled = true;
$(this).attr ( {"disabled": true} );

var targBtn = $("#mainButton");
var overlayDiv = $('<div id="tmBtnOverlay">').css ( {
'width': targBtn.outerWidth (),
'height': targBtn.outerHeight (),
'position': 'absolute',
'top': targBtn.offset ().top,
'left': targBtn.offset ().left,
'z-index': 8888,
'background': "lime",
'opacity': "0.2"
} )
.appendTo ("body");

overlayDiv.click ( function (zEvent) {
//-- Guard against more global handlers.
zEvent.stopImmediatePropagation ();

logline ("Doing some AJAXy thing... <span>&nbsp;</span>");

//-- Simulated AJAX call:
setTimeout (doSomeAjaxyThing, 1111);
} );
} );

function doSomeAjaxyThing () {
$("#eventLog > p > span").first ().text ('Done.');

//-- Now send required events to the original button:
var clickEvent = document.createEvent ('MouseEvents');
clickEvent.initEvent ("click", true, true);
$("#mainButton")[0].dispatchEvent (clickEvent);
}

function logline (str) {
this.lineNumber = this.lineNumber + 1 || 1;
var lineDisplay = (1e15 + this.lineNumber + "").slice (-3); //-- zero pad 3 places

$("#eventLog").prepend ('<p>' + lineDisplay + ' &nbsp; ' + str + '</p>');
}
#mainButton {
font-size: 2em;
padding: 0.3ex 2ex;
}
#eventLog {
max-height: 50vh;
overflow-y: auto;
overflow-x: hidden;
}
#eventLog > p {
margin: 0.3ex 2ex;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.0/jquery.min.js"></script>

<p><button id="mainButton">The Button</button></p>

<p><button id="tmIntercept" autocomplete="off">Hijack the button</button></p>

<fieldset>
<legend>Event Log:</legend>
<div id="eventLog"></div>
</fieldset>


注意事项:

  1. 在某些情况下,您可能会想直接调用页面的代码。但触发事件通常更简单、更可靠且更安全。
  2. 这只是叠加过程的演示。实际上,简单的绝对定位可能需要调整。 (通常将目标节点包裹在相对定位的div中并调整偏移量。)这超出了本题的范围。

关于javascript - 是否可以让其他 javascript 事件监听器等待异步事件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35416783/

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