- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在寻找一种方法来防止事件监听器在另一个事件监听器确认可以继续之前接收到任何事件通知。
我最初的想法是绑定(bind)我的事件监听器,以确定是否应触发该元素的所有其他事件监听器,作为链中的第一个事件监听器。经过调查后 - 这似乎不可能(至少在我将事件监听器绑定(bind)到元素的方式组合中不可能)。
提供一些背景信息:
我在网页上有一个项目列表。当用户单击这些“项目链接”之一时,页面的另一个区域将填充一个表单,用户可以在其中修改项目的某些属性。为了保留已修改项目的属性,用户必须单击与表单相关的“更新”按钮。
我的目标是确保,如果用户在未单击“更新”的情况下修改项目的属性,但随后单击另一个“项目链接”,他们必须确认他们愿意忽略刚刚所做的更改。
我尝试的解决方案:
问题是“item links”元素已经有一个 (Java) Spring AJAX decoration单击事件监听器来更新允许用户修改项目属性的页面部分,并且始终在显示确认的事件监听器之前调用该部分。实际上,我认为我无法在 AJAX 装饰之前绑定(bind)事件监听器以进行确认,以确保在更新页面的项目属性表单部分之前显示确认。
有人有什么建议吗?
更新:
建议的解决方案是将“捕获”标志设置为 true。因此,我向“项目链接”添加事件监听器的代码现在如下所示:
$("." + linkClassName).each(function()
{
if ($.browser.msie)
{
this.setCapture(true);
this.attachEvent("onclick", _self.linksFunction);
}
else
{
this.addEventListener("click", _self.linksFunction, true);
}
});
但是,在将日志记录(到 Firefox 控制台)添加到单击“项目链接”时调用的所有函数后,我的函数 linksFunction
仍然是最后一个被调用的。我是不是做错了什么?
最佳答案
使用
addEventListener
与
capture
设置为 true。
在这里阅读所有相关内容:https://developer.mozilla.org/en/DOM/element.addEventListener
更新:
如果需要IE支持,
use setCapture .
它仅支持鼠标事件,但据我所知,这就是您所需要的。
再次更新:
抱歉,我太快了,使用捕获是一个无用的答案,因为它无法解决您的问题。
我认为做你想做的事情的唯一方法是使用全局点击委托(delegate)。这样,您将拥有一个点,所有点击事件都将通过该点,因此您可以通过那里控制事件。
此解决方案有几个缺点,但您可能不喜欢。一个明显的问题是您可以忘记正常的事件冒泡,因为委托(delegate)是基于冒泡阶段的最后一步。另一个问题是您必须以与习惯完全不同的方式附加事件。
也就是说,如果您能接受这一点,它可能是一种处理点击事件的绝佳方式,我自己在过去几年中更喜欢使用这种方式。您最终只会在整个页面(在 document.body 上)中注册一个单击事件,然后围绕将事件绑定(bind)/取消绑定(bind)到 css 选择器以及在需要时手动触发构建一个小型框架。
此方法的一些好处是您可以在元素存在之前注册单击事件,因为您没有在元素本身上注册它们,如果您使用客户端模板动态构建网站,这非常有用。
关于javascript - 拦截 JavaScript 事件调用(添加事件监听器以始终首先调用或备用),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4880988/
当我使用路径文件上的快捷方式在文件之间移动时,似乎我不仅仅是在文件之间移动。 我使用>转到一个文件,在该文件中我更改光标的位置并执行某些操作,然后按 gf noremap 关于vim 通过快捷方式直
我正在尝试使用 Pong P. Chu 的书来学习 Verilog。我有一个关于如何评估和实现始终 block 的问题。作者代码中的风格让我感到困惑。 在此示例中,他编写了一个具有两个输出寄存器“y1
我正在尝试制作一个聊天应用程序,因此我需要它始终接收服务器信息。因此,当请求完成时,在: http.onreadystatechange=function(){ 我再次调用该函数,因此: reques
当您在 always block 敏感度列表中使用通配符 @* 时,我对什么被视为输入有点困惑。例如,在下面的示例中,哪些信号被解释为导致 always block 被重新评估的输入? 据我了解,cl
我有一个充当调试器的程序。我为线程设置了一个 hw bp,将 dr0 设置为我希望 bp 所在的地址,将 dr7 设置为 1,因为我希望 bp 在每次执行该地址时生成一个事件。 它有效,但现在的问题是
如何每次都以管理员身份在 Windows 上运行 git bash。 操作系统 - Windows 10 家庭版 64 位 最佳答案 我在 Google 上找到了这个结果: 将 Git Bash 设置
使用 accept() 时或 getpeername() , sockaddr_storage总是有 ss_family=AF_INET6 : struct sockaddr_storage addr
我在 Cordova 方面还有另一个问题。我想在 Cordova 7.1.0 中使用插件“cordova.custom.plugins.exitapp”和“cordova-plugins-printe
我试图让模块通过 ISE 12.4 中的语法检查,但它给了我一个我不明白的错误。首先是代码片段: parameter ROWBITS = 4; reg [ROWBITS-1:0] temp; genv
我正在使用Cordova开发适用于iOS的应用程序,其中包括地理位置功能(我使用官方插件https://github.com/apache/cordova-plugin-geolocation)。我在
我想知道是否有可能只在敏感列表中的多个信号一起变化时才执行 always block 。 例如,假设我有一个信号“in”和另一个“posedge clk”。我希望在两个信号都发生变化时执行 alway
我需要实现一种算法来访问数据库来检查最后一个元素,以便计算新的元素。当然,第一次这是不可能的,因为数据库是空的,我得到 IndexOutOfBoundsException) index 0 reque
我正在利用我在网上找到的画廊系统,根据鼠标图像的接近程度,它会按比例增长。 链接:Gallery 好吧,我调整了代码以响应(如您所见正在 build 中)并且没有明显的问题。我的问题在更改分辨率时开始
我正在创建一个 kiosk 应用程序,我想确保它无论如何始终位于其他 Windows 应用程序和 Windows 任务栏之上。 我已经阻止了 Windows 键盘命令(alt-tab 等),但仍有可能
我即将开始一个新的 React 项目,并尝试利用我以前的知识来创建一些关于我如何构建应用程序的规则。 有些事情我认为是真的: Redux 保存整个应用程序的“主要”数据 如果需要跨应用程序共享,Red
当你打开 VS Code 时,终端默认是在底部打开的。您可以单击该图标将其向右移动。我想知道是否有办法将右侧打开设置为默认值。 谢谢。 最佳答案 是的 - 在 v1.20 中引入了设置 workb
我有一个Events表,其中包含各种类型的事件。我只关心其中一种类型。因此,我编写的每个查询都以开头 Events.objects.filter(event_type="the_type").\
我在单例中创建了一个Timer,并且我一直在努力解决为什么Timer没有触发。我查看了这里的帖子,但没有找到我认为可以直接回答我的问题的帖子。 class ConnectionStateMonitor
我在 TableViewController 中显示了一组项目。它们在 TVC 中正确显示。下面的代码会继续,但它只会继续到我的 MKMapItem 数组的 indexPath 0,而不是被单击的单元
我的 VC 是这样的: var coins = 50 // coins override func viewDidLoad() { super.viewDidLoad() if(SKP
我是一名优秀的程序员,十分优秀!