【发布时间】: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