- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想劫持一个网页(使用 Tampermonkey),它有一个带有一些事件监听器的按钮,最后是一个重定向。
有没有办法将我自己的点击事件处理程序添加到按钮,发出 AJAX 请求,并在继续处理其他事件监听器之前等待它完成,所以我的 AJAX 请求肯定在重定向之前完成?
我知道 stopImmediatePropagation但不是如何异步“延迟”传播。
最佳答案
不,您不能让其他事件处理程序等待。您有时可以覆盖/劫持现有函数,但这通常无法使用 Tampermonkey 实现,并且可能会变得困惑(例如在 Firefox + Greasemonkey 中)。
对于像按钮这样的可点击元素,一种解决方法是覆盖按钮,在其上设置监听器,然后让它们在时机成熟时在原始按钮上触发所需的事件。
例如,请考虑以下代码段:
#mainButton
及其代码代表原始页面。//--------------------------
//--- 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> </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 + ' ' + 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>
注意事项:
关于javascript - 是否可以让其他 javascript 事件监听器等待异步事件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35416783/
当单击复选框(或选择所有复选框)时,我想向 CheckboxSelectionModel 添加一个监听器。 var smSensors = new xg.CheckboxSelectionModel(
我有一个简单的程序,允许 2 个客户端连接到服务器。 连接后,他们可以轮流点击空白卡片图像。 一旦 2 个客户中的任何一个点击空白卡片图片,卡片图片将变为 Ace 俱乐部图片。 更改将显示在客户端的两
我在这里看到了一个代码,该代码以字符串的形式检索鼠标的当前图标,但是此代码使用了TTimer来实现。 因此,我想知道是否存在某些事件(侦听器)来检测鼠标光标图标上的这些更改。 下面是使用TTimer的
我想在我的配置对象上获得一个 onload 事件。 以下工作,除非我创建一个 config.listeners={..} (我认为这就是我需要的?)替换 this.onload({...}); 我什至
通常,在 Java 中,当我有一个向其他对象提供某种通知的对象时,我将使用 Listener/Observer 模式。 有没有更类似于 Scala 的方式来做到这一点?我应该在 Scala 中使用这种
我有一个带有动画器的游戏对象和一些可以触发事件的动画(具有特定的回调函数)。 只要我将脚本添加到与动画器相同的游戏对象(包括接收器),一切都会正常工作: public class AnimatorEv
我有一个带有监听器的 DialogFragment,用于单击按钮以调用 fragment 中的函数。 我收到 lateinit property listener has not been initi
这个问题已经有答案了: Java ActionListener error: incompatible types (4 个回答) 已关闭 5 年前。 我最近刚刚开始学习 Java 代码。我在添加监听
我的代码遇到问题。我想知道是否有一种更简单的方法来使用监听器,而不是不断地这样做: example.addActionListener(new java.awt.event.ActionListene
有没有办法使用 .net 创建控制台应用程序。或通过某个端口监听 SMTP 消息的服务? 我需要创建一个中间层对象来捕获和处理 smtp 消息。也就是说,我希望该监听器发送和接收 smtp 消息,然后
我有一个带有动画器的游戏对象和一些可以触发事件的动画(具有特定的回调函数)。 只要我将脚本添加到与动画器相同的游戏对象(包括接收器),一切都会正常工作: public class AnimatorEv
我有许多向主事件生成服务注册的监听器。然而,我想告诉听众,事件流在某个时刻将会结束。您会通过简单地调用监听器上的方法(例如 finish())来完成此操作,还是有一个单独的事件方法 streamFin
我的代码有什么问题。 我创建了一个 JList,添加了项目并将其推到左侧(BorderLayout.WEST)。每次单击列表项时,我希望在列表右侧显示一个面板。但问题是,当选择列表项并运行监听器时,到
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 8 年前。 Improve th
这可能是一个简单的问题,但我没有看到它。 我有一个界面 public interface RenderableListener{ public void update(T element);
有人可以直接指出我的正确方向吗?当从组合框中选择适当的选项时,我希望小程序中的 Action 监听器显示从 html 文件检索的 jlabel 中的 3 个参数之一。 干杯 最佳答案 对于组合框,您需
我有一个网站,每个页面上都有许多 jQuery 事件处理程序,所有这些都在一个大型 .js 文件中。 这意味着对于任何页面,大多数事件处理程序都是针对不存在且根本不会使用的 HTML。 这会影响我的表
我有一些 jQuery 监听器设置,用于监听 type="text" 字段上的表单输入。但是,当用户从自动完成下拉框中选择一个选项(即他们之前输入的值已被记住以供将来使用)时,下面的监听器不会收集该值
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 9 年前。 Improve this ques
我正在用 unity (c#) 做一个类似国际象棋的游戏,但我在尝试进行向上转换以将信息从一个 child 发送到另一个抽象类时遇到了困难。 基本上,我有一个抽象类,它有一个带有函数的事件/委托(de
我是一名优秀的程序员,十分优秀!