上传多个文件

上传多个文件



<!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>

转载于:https://www.cnblogs.com/QxkWeb/p/8028753.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值