<html>
<head>
<meta charset="utf-8">
<title>Chrome,Safari,Firefox3,IE6,IE7,IE8上传图片预览</title>
</head>
<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
<h2>Chrome,Safari,Firefox3,IE6,IE7,IE8上传图片预览</h2>
<!--用来上传文件,注意,input不能display:none,否则ie因为安全原因会获取到空路径-->
<input id="upload_img" type="file">
<br><br>
<!--用来作为预览图片的载体-->
<div id='preview' style="width:200px;height:200px;border: 1px solid #666;background-size:cover;"></div>
<br><br>
<button type="button" onclick="closePreview()">关闭预览</button>
<script type="text/javascript">
$('#upload_img').on('change',function(){
//alert(this.value);
preview(this);
});
function preview(file){
var preview_image = $("#preview");
//webkit
if (file.files && file.files[0]) {
//chrome,safari
var reader = new FileReader();
reader.onload = function (evt) {
//alert(evt.target.result);
preview_image.css('background-image', 'url(' + evt.target.result, + ')');
};
reader.readAsDataURL(file.files[0]);
// Firefox 因安全性问题已无法直接通过 input[file].value 获取完整的文件路径
if(!reader)
preview_image.css('background-image', 'url(' + file.files[0].getAsDataURL(), + ')');
}
else//IE6-10
{
//input的select()和document.selection.createRange().text非常关键,确保imgSrc获取到真实路径
file.select();
var imgSrc = document.selection.createRange().text;
alert(imgSrc);
var imgDiv = document.getElementById("preview");
imgDiv.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod = scale)";
imgDiv.filters("DXImageTransform.Microsoft.AlphaImageLoader").src = imgSrc;
}
}
//关闭预览
function closePreview(){
//webkit
var preview_image = $("#preview");
preview_image.css("background-image", "none");
//ie
var imgDiv = document.getElementById("preview");
imgDiv.style.filter = "none";
}
</script>
</body>
</html>
各种浏览器通用图片上传预览
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- HTML5有个功能就可以将图片转换base64,那就是FileReader。同时我们也需要对图片大小执行限制和压缩...
- 最快速简单的实现附件(各种类型文件,doc,word,excel,ppt,pdf,MP4,MP3,apk,等等)上...
- 页面如何通过input标签来显示获取的图片? 之所想到这个问题是因为某次做动画的时候,需要获取transform-...