开发者问题收集

未捕获的类型错误:无法读取未定义的属性(读取“dataTransfer”)

2021-12-09
2989

我有一段代码,用于将文件拖放到某个区域:

//track drop
document.getElementById("track-drop").addEventListener("dragenter", function(e) {
  e.preventDefault();
  e.target.classList.add("drag-enter");

  console.log("Event: dragenter")
});

document.getElementById("track-drop").addEventListener("dragover", function(e) {
  e.preventDefault();

  console.log("Event: dragover")
});

document.getElementById("track-drop").addEventListener("dragleave", function(e) {
  e.preventDefault();
  e.target.classList.remove("drag-enter");

  console.log("Event: dragleave")
});

document.getElementById("track-drop").addEventListener("drop", function(e) {
  e.preventDefault();
  e.target.classList.remove("drag-enter");

  console.log("Event: drop")

  var dropEvent = e.originalEvent;

  for (var i = 0; i < dropEvent.dataTransfer.files.length; i++) {
    console.log("New file: ", dropEvent.dataTransfer.files[i]);
  }
});
.track-drop {
  border: 2px dashed blue;
  height: 100px;
  width: 200px;
  margin: 1em 0;
}

.track-drop::before {
  content: "Drop file(s) here!";
}

.track-drop.drag-enter {
  border: 2px solid orange;
}
<div class="track-drop" id="track-drop"></div>

问题是收到错误:

Uncaught TypeError: Cannot read properties of undefined (reading 'dataTransfer')

在此 JS 语句中: dropEvent.dataTransfer.files.length

调试器

在我的代码中,调试器指示 e.originalEvent 不存在。但 e.dataTransfer 存在。我不明白为什么。

Breakpoint

Debugger watcher

注意

同样的代码在另一个网页上运行良好。令人惊讶的是,那里存在 e.originalEvent 。但 e.dataTransfer 却不行。

Good web page

问题

我不明白为什么该代码适用于其他网页,而 适用于我的网页。我是否遗漏了依赖项或其他什么?

2个回答

我认为您的错误可以通过直接从事件中读取 dataTransfer 来解决,如下所示:

for (var i = 0; i < e.dataTransfer.files.length; i++) {
  console.log("New file: ", e.dataTransfer.files[i]);
}
Saeed Shamloo
2021-12-09

我知道这是一个老问题,但我也遇到过类似的问题。 将 e 更改为 event 即可解决问题

var dropEvent = event.originalEvent;

  for (var i = 0; i < dropEvent.dataTransfer.files.length; i++) {
    console.log("New file: ", dropEvent.dataTransfer.files[i]);
  }
Carlos M
2024-02-16