图片预览首先,解决图片预览问题。在html5中,提供了filereader来读取本地文件,使我们可以实现图片预览功能。
filereader属性,所有属性都是只读的:
filereader.error,读取文件时,出现的domerror。
filereader.readystate,读取状态;0,没有数据加载;1,数据正在加载;2,读取已经完成。
filereader.result,文件内容;该属性只在读取操作完成后才有效,并且格式取决于读取时使用的方法。
事件:
filereader.onabort,读取操作中止。
filereader.onerror,读取出现错误。
filereader.onload,读取成功完成后。
filereader.onloadstart,读取开始。
filereader.onloadend,读取完成,无论是否读取成功。
filereader.onprogress,当读取blob内容时。
方法:
filereader.abort()
中止读取。然后readystate变为2。
filereader.readasarraybuffer()
将文件读取成arraybuffer。
filereader.readasbinarystring()
读取成二进制字符串。
filereader.readasdataurl()
读取成dataurl。
filereader.readastext()
读取成文本。
浏览器兼容性如图:
预览功能实现<!doctype html><html><head><meta charset="utf-8"><title>图片上传预览</title><script type="text/javascript"> function imgpreview(filedom){ //判断是否支持filereader if (window.filereader) { var reader = new filereader(); } else { alert("您的设备不支持图片预览功能,如需该功能请升级您的设备!"); } //获取文件 var file = filedom.files[0]; var imagetype = /^image\//; //是否是图片 if (!imagetype.test(file.type)) { alert("请选择图片!"); return; } //读取完成 reader.onload = function(e) { //获取图片dom var img = document.getelementbyid("preview"); //图片路径设置为读取的图片 img.src = e.target.result; }; reader.readasdataurl(file); }</script></head><body> <img id="preview" /> <br /> <input type="file" name="file" onchange="imgpreview(this)" /></body></html>
效果预览:
上传功能function upload() { var xhr = new xmlhttprequest(); var progress = document.getelementbyid("progress") progress.style.display = "block"; xhr.upload.addeventlistener("progress", function(e) { if (e.lengthcomputable) { var percentage = math.round((e.loaded * 100) / e.total); progress.value = percentage; } }, false); xhr.upload.addeventlistener("load", function(e){ console.log("上传完毕...") }, false); xhr.open("post", "upload"); xhr.overridemimetype('text/plain; charset=x-user-defined-binary'); xhr.onreadystatechange = function() { if (xhr.readystate == 4 && xhr.status == 200) { alert(xhr.responsetext); // handle response. progress.style.display = "none"; progress.value = 0; } }; var file = document.getelementbyid("imgfile"); var fd = new formdata(); fd.append(file.files[0].name, file.files[0]); xhr.send(fd); }
以上就是通过html5实现图片上传与预览功能的详细内容。
