如何防止子元素干扰 HTML5 拖放事件?

How to keep child elements from interfering with HTML5 dragover and drop events?(如何防止子元素干扰 HTML5 拖放事件?)
本文介绍了如何防止子元素干扰 HTML5 拖放事件?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我有一个 <div> 放置目标,我已将 'drop' 和 'dragover' 事件附加到该目标.<div> 包含锚标记内的图像(简单地说:<div><a><img/></a></div>).目标的子元素似乎阻止触发drop"或dragover"事件.只有当被拖动的元素在目标上方而不是在其子元素上方时,这两个事件才会按预期触发.

I have a <div> drop target that I have attached 'drop' and 'dragover' events to. The <div> contains an image inside an anchor tag (simplistically: <div><a><img /></a></div>). The child elements of the target seem to block the 'drop' or 'dragover' events from being triggered. Only when the dragged element is over the target, but NOT over its child elements, are both events triggered as expected.

我想要实现的行为是,无论是否存在子元素,都会在目标 <div> 上的任何位置触发 'dragover' 和 'drop' 事件.

The behavior I would like to achieve is that the 'dragover' and 'drop' events are triggered anywhere over the target <div>, regardless of the existence of child elements.

推荐答案

您可以在 CSS 中为所有子级禁用指针事件.

You can disable the pointer-events in CSS for all children.

.targetDiv * {
    pointer-events: none;
}

这篇关于如何防止子元素干扰 HTML5 拖放事件?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

Drag amp; Drop with Protractor by Repeater(拖动amp;通过中继器使用量角器掉落)
Getting the position of the element in a list when it#39;s drag/dropped (ui.sortable)(拖放时获取元素在列表中的位置(ui.sortable))
Detecting HTML5 Drag And Drop support in javascript(在 javascript 中检测 HTML5 拖放支持)
HTML5 drop event doesn#39;t work unless dragover is handled(除非处理了拖动,否则 HTML5 放置事件不起作用)
How to use jQuery#39;s drop event to upload files dragged from the desktop?(如何使用 jQuery 的 drop 事件上传从桌面拖动的文件?)
Drop image into contenteditable in Chrome to the cursor(将图像拖放到 Chrome 中的 contenteditable 到光标处)