【问题标题】:Drop event not getting file list删除事件未获取文件列表
【发布时间】:2021-10-21 18:35:28
【问题描述】:

我想从浏览器中拖出一张图片并将其放到一个对象中,然后像这样简单地获取拖放的文件:

$('#image-upload-preview').on('drop', drop);

function drop(e) {
  const file = e.originalEvent.dataTransfer;
  console.log('file', file[0]); // this brings undefined
  //console.log('file', file); // this bring empty file list
}

window.addEventListener("dragover", (e) => {
  e = e || event;
  e.preventDefault();
}, false);

window.addEventListener("drop", (e) => {
  e = e || event;
  e.preventDefault();
}, false);
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="image_container">
  <img id="image-upload-preview" style="width:100%" src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcSClDjLZzrjD5FHPX-nNU5QoTWK-C2XcOD-M6Aabozw6Oem8-0ejje8Lk5DmNbhVOvvMfc&usqp=CAU">
  <div id="cropped_result"></div>
</div>

但是文件返回空文件列表???

我该如何解决这个问题?

【问题讨论】:

  • e.originalEvent.dataTransfer 返回一个对象,而不是一个数组(您可以使用typeof file 进行检查)

标签: javascript jquery


【解决方案1】:

你没有得到文件列表,因为你的 const 不正确。

你需要放 .files : e.originalEvent.dataTransfer.const.files

$('#image-upload-preview').on('drop', drop);

function drop(e) {
  e.stopPropagation();
  e.preventDefault();

  var file = e.originalEvent.dataTransfer.files;
  var fd = new FormData();

  console.log(file[0]);

  fd.append('file', file[0]);
  
  // process upload with ajax
}

window.addEventListener("dragover", (e) => {
  e = e || event;
  e.preventDefault();
}, false);

window.addEventListener("drop", (e) => {
  e = e || event;
  e.preventDefault();
}, false);
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="image_container">
  <img id="image-upload-preview" style="width:100%" src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcSClDjLZzrjD5FHPX-nNU5QoTWK-C2XcOD-M6Aabozw6Oem8-0ejje8Lk5DmNbhVOvvMfc&usqp=CAU">
  <div id="cropped_result"></div>
</div>

【讨论】:

  • 从浏览器中拖放一张图片,你又得到了未定义...你想知道为什么吗?
  • 我正在使用 Firefox,它可以与拖放图像一起使用 @SaraRee 我尝试使用 Chrome 并且它也可以。
  • 拖动从另一个 chrome 选项卡打开的图像并尝试删除它....该代码仅在您从计算机而不是从浏览器的打开选项卡中删除图像时才有效...请确认这一点..
猜你喜欢
  • 1970-01-01
  • 2015-09-23
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-03-19
  • 1970-01-01
  • 1970-01-01
  • 2013-10-08
相关资源
最近更新 更多