文件拖拽

2018-02-24

准备工作

JS拖动事件

  • 在拖动目标上触发事件 (源元素):
    • ondragstart - 用户开始拖动元素时触发
    • ondrag - 元素正在拖动时触发
    • ondragend - 用户完成元素拖动后触发
  • 释放目标时触发的事件:
    • ondragenter - 当被鼠标拖动的对象进入其容器范围内时触发此事件
    • ondragover - 当某被拖动的对象在另一对象容器范围内拖动时触发此事件
    • ondragleave - 当被鼠标拖动的对象离开其容器范围内时触发此事件
    • ondrop - 在一个拖动过程中,释放鼠标键时触发此事件

详细事件说明可参考web技术文档–>事件类型–>拖放事件

file对象[FileReader对象]

FileReader主要用于将文件内容读入内存,通过一系列异步接口,可以在主线程中访问本地文件。

使用FileReader对象,web应用程序可以异步的读取存储在用户计算机上的文件(或者原始数据缓冲)内容,可以使用File对象或者Blob对象来指定所要处理的文件或数据。

创建实例

var reader = new FileReader();

方法

方法定义 描述
abort():void 终止文件读取操作
readAsArrayBuffer(file):void 异步按字节读取文件内容,结果用ArrayBuffer对象表示
readAsBinaryString(file):void 异步按字节读取文件内容,结果为文件的二进制串
readAsDataURL(file):void 异步读取文件内容,结果用data:url的字符串形式表示
readAsText(file,encoding):void 异步按字符读取文件内容,结果用字符串形式表示

事件

事件名称 描述
onabort 当读取操作被中止时调用
onerror 当读取操作发生错误时调用
onload 当读取操作成功完成时调用
onloadend 当读取操作完成时调用,不管是成功还是失败
onloadstart 当读取操作将要开始之前调用
onprogress 在读取数据过程中周期性调用

详细事件说明可参考web技术文档–> Web API 接口–>FileReader

直接上代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>文件拖拽+图片预览</title>
<style type="text/css">
.dragbox{
width: 300px;
height: 300px;
margin: 20px;
border: 3px dashed #e6e6e6;
}
.range{
margin: 75px auto;
width: 150px;
height: 150px;
display: block;
background-repeat: no-repeat;
background-position: center;
background-size: cover;
background-image: url("");
}
#preview img{
width: 200px;
height: 200px;
}
</style>
</head>
<body>
<div id="dragbox" class="dragbox">
<label for="file" class="range"></label>
<input type="file" id="file" style="display: none">
</div>
<div id="preview"></div>
<script type="text/javascript">
//文件拖拽事件
var dropbox = document.getElementsByClassName("dragbox");
var preview = document.getElementById("preview");
dropbox[0].addEventListener("dragenter", function(e){
e.stopPropagation();
e.preventDefault();
}, false);
dropbox[0].addEventListener("dragover", function(e){
e.stopPropagation();
e.preventDefault();
}, false);
dropbox[0].addEventListener("drop", function(e){
e.stopPropagation();
e.preventDefault();
var dt = e.dataTransfer;
var files = dt.files;
update(files);
}, false);
//input选择图片
var file = document.getElementById("file");
file.addEventListener("change",function () {
var files = this.files;
if (!!files) {
update(files);
}
});
function update(files) {
for (var i = 0; i < files.length; i++) {
var file = files[i];
var imageType = /^image\//;
if ( !imageType.test(file.type) ) {
continue;
}
// 填充选择的图片到展示区
var img = document.createElement("img");
img.classList.add("obj");
preview.appendChild(img);
// 读取File对象中的内容
var reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = (function(aImg) {
return function(e) {
aImg.src = e.target.result;
};
})(img);
}
}
</script>
</body>
</html>

实例预览

点击+拖拽上传前预览