原生JavaScript实现异步多文件上传
这是在上篇的修改版本。后台代码不变就可以接着使用,但是脚本不再使用jQuery了,改为原生的JavaScript代码,所以我们主要看JS代码。
先介绍一下技术参数:
页面技术:HTML5
后台技术:Servlet3.0
服务器:Tomcat7.0
脚本:JavaScript
HTML5file组件的新属性
accept:如果在file组件中增加这个属性就可以直接控制上传的文件类型了,实在是很方便。
multiple:是否允许选择多个文件
HTML5页面代码修改后
<imgwidth="400"height="250"/><br/> <inputtype="file"id="pic"name="pic"onchange="printFileInfo()"accept="image/*"multiple="multiple"/> <inputtype="button"value="上传图片"onclick="uploadFile()"/><br/> <divid="parent"> <divid="son"></div> </div>
accept的值可以参阅:IANAMIME类型(标准MIME类型的完整列表),如果使用的是DW开发的话,软件本身就有提示。
如果选择了多个文件,可以用JS做循环打印,看看文件的名称,类型和大小,看演示代码
functionprintFileInfo(){ varpicFile=document.getElementById("pic"); varfiles=picFile.files; for(vari=0;i<files.length;i++){ varfile=files[i]; vardiv=document.createElement("div") div.innerHTML="第("+(i+1)+")个文件的名字:"+file.name+ ",文件类型:"+file.type+",文件大小:"+file.size document.body.appendChild(div) } }
既然可以循环多文件的话,就可以尝试多文件上传了。
1、首先创建XMLHttpRequest对象
//这是全局变量。因为是示例,所以就没有判断浏览器类型,低版本IE这么写的话会出问题的
varxhr=newXMLHttpRequest()
2、上篇介绍了进度事件(Progress),这次实现progress和error2个事件
error:在请求发生错误时触发。
对应上传时发生错误导致的上传失败:uploadFailed()
//上传失败 functionuploadFailed(evt){ alert("上传失败"); } progress:在接收相应期间持续不断触发。 对应上传进度方法:onprogress() /** *侦查附件上传情况,这个方法大概0.05-0.1秒执行一次 */ functiononprogress(evt){ varloaded=evt.loaded;//已经上传大小情况 vartot=evt.total;//附件总大小 varper=Math.floor(100*loaded/tot);//已经上传的百分比 $("#son").html(per+"%"); $("#son").css("width",per+"%"); }
最后就是上传方法了,注意上面的html代码中上传用的方法也需要改成这个uploadFile()方法才能正常使用。
//上传文件 functionuploadFile(){ //将上传的多个文件放入formData中 varpicFileList=$("#pic").get(0).files; varformData=newFormData(); for(vari=0;i<picFileList.length;i++){ formData.append("file",picFileList[i]); } //监听事件 xhr.upload.addEventListener("progress",onprogress,false); xhr.addEventListener("error",uploadFailed,false);//发送文件和表单自定义参数 xhr.open("POST","upload"); //记得加入上传数据formData xhr.send(formData); }
PS:这毕竟只是基本功能的演示示例,离公司使用的要求还相差十万八千里,请谨慎在公司平台使用。
大家可以结合这篇文章进行学习:基于HTML5Ajax文件上传进度条如何实现(jquery版本)
以上就是本文的全部内容,希望对大家的学习有所帮助。