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上传文件预览的简单实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。