码迷,mamicode.com
首页 > Web开发 > 详细

上传多个文件

时间:2017-12-12 22:16:04      阅读:199      评论:0      收藏:0      [点我收藏+]

标签:val   change   rom   ima   length   foreach   add   gpo   lan   

上传多个文件



<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>批量上传文件</title>
</head>
<body>
<input type="file" multiple value="上传文件" id="file">
<div class="box">

</div>
</body>
<script>
let selectFile = document.getElementById(‘file‘);
let preview = document.getElementsByClassName(‘box‘)[0];
function setSelectFileBehavior(subjects) {
if(!Array.isArray(subjects)){
if(subjects.length) subjects = Array.from(subjects);
else subjects = [subjects]
}
subjects.forEach(subject => {
subject.addEventListener(‘change‘,evt =>{
let fileInput = evt.target;
let files = Array.from(fileInput.files);
let URL = window.URL || window.webkitURL;
if(typeof FileReader === ‘function‘){
files.forEach(file => {
let reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = function (evt) {
let event = new CustomEvent(‘fileselect‘,{
detail:{
dataURL:evt.target.result
}
});
subject.dispatchEvent(event);
}
})
} else if(URL){
files.forEach(file => {
let blob = URL.createObjectURL(file);
let event = new CustomEvent(‘fileselect‘,{
detail:{
blob:blob
}
});
subject.dispatchEvent(event);
});
}
})
})
}
setSelectFileBehavior(selectFile);
selectFile.addEventListener(‘change‘,evt => {
preview.innerHTML = ‘‘;
});
selectFile.addEventListener(‘fileselect‘,evt => {
let img = new Image();
img.src = evt.detail.dataURL || evt.detail.blob;
img.style.padding = ‘5px‘;
img.style.height = ‘150px‘;
preview.appendChild(img);
})
</script>
</html>

上传多个文件

标签:val   change   rom   ima   length   foreach   add   gpo   lan   

原文地址:http://www.cnblogs.com/QxkWeb/p/8028753.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!