- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我放了一个全局模态“加载中,请稍候”<div>
在应用程序中。每次都显示 <a>
或 <input type="button">
被点击。这是通过分配 <body>
来实现的一个onclick
onload
中的事件处理程序,以便在事件冒泡时执行:
<body onload="setup()">
<!-- No control over what will be here -->
</body>
<script>
function setup() {
document.getElementsByTagName('body')[0].onclick = clickFunc;
}
function clickFunc(eventData) {
var clickedElement = (window.event) ? event.srcElement : eventData.target;
if (someConditions) {
document.getElementById('modal').style.display = "block";
}
}
</script>
现在,我在标记中有一些组件(我无法控制)执行 return false
在他们的 onclick
秒。这导致模式弹出窗口显示并在有 confirm()
时停留在那里并且用户否认。处理这个问题的正确方法可能是 preventDefault()
,这样事件就不会冒泡,如 event.preventDefault() vs. return false 中所述。 .
但我无法控制那部分,所以:有没有办法(最好是非 jquery+跨浏览器)知道事件处理程序先前执行的结果(在较低级别)?
如果没有,我想我只能避免显示模态 <div>
每当组件的 onclick
包含 return false
.
这是一个JSFiddle用于测试。
下面 Bergi 的回答正是我要搜索的内容。然而,defaultPrevented
IE < 9 似乎不受支持。在 IE < 9 中是否有等效/解决方法来实现该功能?
最佳答案
您可以检查 (window.event ? event.defaultPrevented : eventData.isDefaultPrevented()) == false
以捕获没有返回 的传播事件 假的
。
关于javascript - 知道事件的先前处理程序是否返回 false。 defaultPrevented 在 IE < 9 中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12641152/
我的应用将 SceneKit 内容的“页面”与图像和文本交替。当我从图像页面前进到新的 SceneKit 页面时,前一个 SceneKit 页面中的内容会短暂显示,然后被新内容替换。时髦。 我只使用一
我正在尝试处理(在 C# 中)包含一些数字数据的大型数据文件。给定一个整数数组,如何对其进行拆分/分组,以便如果下一个 n(两个或更多)是负数,则前一个 n 元素被分组。例如,在下面的数组中,应该使用
刚接触promises,研究过。所以我的代码和我的理解: sql.connect(config).then(function(connection) { return connection.req
目前我在 if (roobaf) block 中有一些代码,这取决于 foo 和 bar 是否为假。我可以在 block 内再次检查这些条件,但感觉像是不必要的代码重复。 if (foo) {
我是一名优秀的程序员,十分优秀!