我想在使用 JQuery 将图像上传到服务器之前创建图像预览。
我的代码,js代码:
$(function(){
Test = {
UpdatePreview: function(obj){
// if IE < 10 doesn't support FileReader
if(!window.FileReader){
// don't know how to proceed to assign src to image tag
} else {
var reader = new FileReader();
var target = null;
reader.onload = function(e) {
target = e.target || e.srcElement;
$("img").prop("src", target.result);
};
reader.readAsDataURL(obj.files[0]);
}
}
};
});
我的html:
<input type='file' name='browse' onchange='Test.UpdatePreview(this)' />
<br/><br/>
<img src="#" alt="test" width="128" height="128" />
见jsfiddle:http: //jsfiddle.net/aAuMU/
之后onload
,我看到图像的 src(使用 Google 控制台应用程序),它看起来像:
data:image/jpeg;base64,/9j/4AAQSkZJRgABAgAAAQABAAD//gAEKgD/4gv4SUNDX1BST0ZJTEUAAQEAAAvoAAAAAAIAAABtbnRyUkdCIFhZWiAH2QADABsA...
这是一种在 javascript 中获取图像基础并分配给图像的方法,以防我使用 IE 作为浏览器?
FileReader
在 IE < 10 中不起作用。