我想知道是否有一种方法可以在javascript / jquery上同时触发2 div上的事件,如果它们位于同一位置但位于不同的z-index上?
示例:
like in this example http://imageshack.com/a/img849/8684/k8jn.jpg
答案 0 :(得分:2)
考虑使用elementFromPoint()
方法:
DEMO jsFiddle {如果使用包装的iframe和scolling body的iframe,请注意错误}
$divs = $("#one, #two").on('click.passThrough', function (e, ee) {
var $el = $(this).hide();
try {
if (!ee) $("#msg").empty();
$("<div/>").append($el.text()).appendTo($("#msg"));
ee = ee || {
pageX: e.pageX,
pageY: e.pageY
};
var next = document.elementFromPoint(ee.pageX, ee.pageY);
next = (next.nodeType == 3) ? next.parentNode : next //Opera
$(next).trigger('click.passThrough', ee);
} catch (err) {
console.log("click.passThrough failed: " + err.message);
} finally {
$el.show();
}
alert('div cliked: #' + this.id);
});
答案 1 :(得分:1)
Listen "mousemove" event in wrapper div,
use event object pageX and PageY to find Cursor above both div or not.