单文件上传:<input type="file" id="file1"/> 多文件上传:<input type="file" id="file2" multiple/>
二、属性(如下三个仅HTML5支持,所以存在兼容性问题
)html
(1)multiple
:表示用户是否能够选择多个值。multiple只能用于type=file和type=email。html5
(2)accept:服务器接受的文件类型,不然将被忽略。
web
音频/ *表明声音文件。仅HTML5支持
视频/ *表明视频文件。仅HTML5支持
图像/ *表示图像文件。仅HTML5支持数组
(3)required:此属性指定用户在提交表单以前必须填写一个值。
浏览器
三、获取上传的文件信息服务器
Input.onchange = function (event) { if(!window.FileReader){ console.log("浏览器不支持HTML5"); return false; } var a = event.target; var b = event.target.files; var c = event.target.files[0]; console.log(a);//input对象 console.log(b);//files数组对象 console.log(c);//第一张图片的file对象 }
能够发现input.files是一个数组,由传入的file对象组成。每一个file对象包含如下属性:异步
lastModified:数值,表示最近一次修改时间的毫秒数;ui
lastModifiedDate:对象,表示最后一次表示最近一次修改时间的Date对象(高程中说是字符串,根据上图可看出应该为对象,为了层级清晰未对其展开,你们可自行查看,其可调用Date对象的有关方法,例如getDay方法);this
name:本地文件系统中的文件名;编码
size:文件的字节大小;
type:字符串,文件的MIME类型;
weblitRelativePath:此处为空;当在input上加上webkitdirectory属性时,用户可选择文件夹,此时weblitRelativePath表示文件夹中文件的相对路径。
以上file对象只获取到了对文件的描述信息,但没有得到文件中的数据,而event.target.value也只是保存的是文件的绝对路径,如图:
咱们能够经过html5提供的FileReader读取到文件中的数据。
首先建立一个FileReader实例:
var reader = new FileReader();
FileReader提供了以下方法:
readAsArrayBuffer(file) | 按字节读取文件内容,结果用ArrayBuffer对象表示 |
readAsBinaryString(file) | 按字节读取文件内容,结果为文件的二进制串 |
readAsDataURL(file) | 读取文件内容,结果用data:url的字符串形式表示 |
readAsText(file,encoding) | 按字符读取文件内容,结果用字符串形式表示 |
abort() | 终止文件读取操做 |
readAsDataURL和readAsText较为经常使用,这里只对这二者进行说明。
readAsDataURL会将文件内容进行base64编码后输出:
var Input = document.querySelector("#file1"); Input.onchange = function (event) { if(!window.FileReader){ console.log("浏览器不支持HTML5"); return false; } var files = event.target.files[0]; var reader = new FileReader(); reader.readAsDataURL(files);//发起异步请求 reader.onload = function(e){ //读取完成后,数据保存在对象的result属性中 console.log(this.result); } }
onabort | 当读取操做被停止时调用 |
onerror | 当读取操做发生错误时调用 |
onload | 当读取操做成功完成时调用 |
onloadend | 当读取操做完成时调用,不管成功或失败 |
onloadstart | 当读取操做开始时调用 |
onprogress | 在读取数据过程当中周期性调用 |
var Input = document.querySelector("#file1"); var count=0; Input.addEventListener("change",function(){ var reader = new FileReader(); reader.readAsText(inputBox.files[0],"utf-8");//发起异步请求 reader.onload = function(){ console.log("加载成功") } reader.onloadstart = function(){ console.log("开始加载") } reader.onloadend= function(){ console.log("加载结束") } reader.onprogress = function(){ count++; console.log("加载中"+count) } })