3

我已经成功地使用 HTML 5 为 Web 应用程序实现了拖放文件上传。我监听 drop 事件,然后从 event.dataTransfer 属性中获取文件数据。

出于所有意图和目的,它的工作方式与 dropzone.js 完全相同:

http://www.dropzonejs.com/

但是,出于某种原因,我无法从 Chrome 下载栏中拖放文件。

在此处输入图像描述

dragenter、dragover 和 dragleave 事件会触发,但不会触发 drop 事件。这可以使用 dropzone.js 演示网站可靠地复制。

为什么?

4

1 回答 1

9

诀窍是默认情况下,传递给的dropEffect属性默认设置为。您需要检测到这一点,并将其设置为复制或移动,具体取决于用例。event.dataTransferdragover'none'

对我来说,将其设置为复制有效。我不必对drop事件做任何事情。只是对dragover事件的修改。

这是我所做的:

// The dragover event
function onDragover(e) {
    if (e.originalEvent) {
        e = e.originalEvent;
    }

    if (!e.dataTransfer) {
        return;
    }

    // Code I added begins here
    var b = e.dataTransfer.effectAllowed;

    e.dataTransfer.dropEffect = ('move' === b || 'linkMove' === b) ? 'move' : 'copy';
    // Code I added ends here

    this.$el.addClass('dragging');

    e.stopPropagation();
    e.preventDefault();
}
于 2013-10-22T20:36:19.870 回答