js 上传文件预览的简单实例
1.FILEAPI
html5提供了FIle和FileReader两个方法,可以读取文件信息并读取文件。
2.example
<html>
<body>
<divid="test-image-preview"
style="border:1pxsolidrgb(204,204,204);width:100%;height:200px;background-size:contain;background-repeat:no-repeat;background-position:centercenter;"></div>
<br/>
<divid="test-file-info"></div>
<br/>
<inputtype="file"id="test-image-file">
<scripttype="text/javascript">
var
fileInput=document.getElementById('test-image-file'),
info=document.getElementById('test-file-info'),
preview=document.getElementById('test-image-preview');
//监听change事件:
fileInput.addEventListener('change',function(){
//清除背景图片:
preview.style.backgroundImage='';
//检查文件是否选择:
if(!fileInput.value){
info.innerHTML='没有选择文件';
return;
}
//获取File引用:
varfile=fileInput.files[0];
//获取File信息:
info.innerHTML='文件:'+file.name+'<br>'+
'大小:'+file.size+'<br>'+
'修改:'+file.lastModifiedDate;
if(file.type!=='image/jpeg'&&file.type!=='image/png'&&file.type!=='image/gif'){
alert('不是有效的图片文件!');
return;
}
//读取文件:
varreader=newFileReader();
reader.onload=function(e){
var
data=e.target.result;//'data:image/jpeg;base64,/9j/4AAQSk...(base64编码)...'
preview.style.backgroundImage='url('+data+')';
};
//以DataURL的形式读取文件:
reader.readAsDataURL(file);
});
</script>
</body>
</html>
以DataURL的形式读取到的文件是一个字符串,类似于data:image/jpeg;base64,/9j/4AAQSk...(base64编码)...,
常用于设置图像。如果需要服务器端处理,把字符串base64,后面的字符发送给服务器并用Base64解码就可以得到原始文件的二进制内容。
3.解释
上面的代码还演示了JavaScript的一个重要的特性就是单线程执行模式。在JavaScript中,浏览器的JavaScript执行引擎在执行JavaScript代码时,总是以单线程模式执行,也就是说,任何时候,JavaScript代码都不可能同时有多于1个线程在执行。
你可能会问,单线程模式执行的JavaScript,如何处理多任务?
在JavaScript中,执行多任务实际上都是异步调用,比如上面的代码:
reader.readAsDataURL(file);
就会发起一个异步操作来读取文件内容。因为是异步操作,所以我们在JavaScript代码中就不知道什么时候操作结束,因此需要先设置一个回调函数:
reader.onload=function(e){
//当文件读取完成后,自动调用此函数:
};
当文件读取完成后,JavaScript引擎将自动调用我们设置的回调函数。执行回调函数时,文件已经读取完毕,所以我们可以在回调函数内部安全地获得文件内容。
以上这篇js上传文件预览的简单实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。