var picFile = document.getElementById("pic"); var files = picFile.files; for(var i=0; ivar file = files[i]; var div = document.createElement("div") div.innerHTML = "第("+ (i+1) +") 个文件的名字:"+ file.name + " , 文件类型:"+ file.type +" , 文件大小:"+ file.size document.body.appendChild( div) } }
既然可以循环多文件的话,就可以尝试多文件上传了。 1、首先创建 XMLHttpRequest 对象 //这是全局变量。因为是示例,所以就没有判断浏览器类型,低版本IE这么写的话会出问题的 var xhr = new XMLHttpRequest() 2、上篇介绍了进度事件(Progress) , 这次实现 progress 和 error 2个事件 error:在请求发生错误时触发。 对应上传时发生错误导致的上传失败:uploadFailed() //上传失败 function uploadFailed(evt) { alert("上传失败"); } progress:在接收相应期间持续不断触发。
对应上传进度方法:onprogress() /** * 侦查附件上传情况 ,这个方法大概0.05-0.1秒执行一次 */ function onprogress(evt){ var loaded = evt.loaded; //已经上传大小情况 var tot = evt.total; //附件总大小 var per = Math.floor(100*loaded/tot); //已经上传的百分比 $("#son").html( per +"%" ); $("#son").css("width" , per +"%"); }