HTML5 CSS3 经典案例:无插件拖拽上传图片 (支持预览与批量)
以下是一个简化的HTML和JavaScript代码示例,用于实现一个基本的拖拽上传图片功能,包括对文件预览的支持。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Drag and Drop Image Upload</title>
<style>
#drop_area {
width: 300px;
height: 200px;
border: 2px dashed #aaa;
border-radius: 5px;
margin: 10px;
padding: 50px;
text-align: center;
font: 20pt bold;
color: #bbb;
}
#preview {
width: 300px;
height: 200px;
border: 2px solid #000;
margin: 10px;
display: none;
}
#preview img {
width: 100%;
height: 100%;
}
</style>
</head>
<body>
<div id="drop_area">Drag images here</div>
<div id="preview"></div>
<script>
const dropArea = document.getElementById('drop_area');
const preview = document.getElementById('preview');
dropArea.addEventListener('dragover', function(e) {
e.stopPropagation();
e.preventDefault();
e.dataTransfer.dropEffect = 'copy';
});
dropArea.addEventListener('drop', function(e) {
e.stopPropagation();
e.preventDefault();
const files = e.dataTransfer.files;
for(let i = 0; i < files.length; i++) {
const file = files[i];
if (!file.type.startsWith('image/')) {
continue;
}
const img = document.createElement('img');
img.file = file;
preview.style.display = 'block';
const reader = new FileReader();
reader.onload = (function(aImg) {
return function(e) {
aImg.src = e.target.result;
};
})(img);
reader.readAsDataURL(file);
// 这里可以添加上传逻辑
// uploadImage(file);
}
});
</script>
</body>
</html>
这段代码实现了基本的拖拽上传图片的功能,并在用户拖拽文件到指定区域时显示图片预览。用户可以通过拖拽操作选择图片文件并将它们放入页面指定的区域。代码中的FileReader
对象用于读取被拖放的图片文件,并利用其readAsDataURL
方法将文件转换为Base64编码的字符串,以便在页面上显示图片。
注意:实际应用中,你需要根据自己的需求和后端API来实现图片的上传逻辑。上传代码被注释掉了,你可以根据实际情况添加上传逻辑。
评论已关闭