兼容好的JS图片上传预览代码
2014-07-20 16:08
676 查看
在上传图片前预览图片的功能,可提高你网站的用户体验,让用户清楚所要上传的图片是不是选对了。本代码无JS插件,纯JavaScript结合HTML来实现,是一个很不错的例子,比较完整:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" > <head> <title>本地图片预览</title> <style type="text/css"> #preview{width:100px;height:100px;border:1px solid #000;overflow:hidden;} #imghead {filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=image);} </style> <script type="text/javascript"> function previewImage(file) { var MAXWIDTH = 100; var MAXHEIGHT = 100; var div = document.getElementById('preview'); if (file.files && file.files[0]) { div.innerHTML = '<img id=imghead>'; var img = document.getElementById('imghead'); img.onload = function(){ var rect = clacImgZoomParam(MAXWIDTH, MAXHEIGHT, img.offsetWidth, img.offsetHeight); img.width = rect.width; img.height = rect.height; img.style.marginLeft = rect.left+'px'; img.style.marginTop = rect.top+'px'; } var reader = new FileReader(); reader.onload = function(evt){img.src = evt.target.result;} reader.readAsDataURL(file.files[0]); } else { var sFilter='filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale,src="'; file.select(); var src = document.selection.createRange().text; div.innerHTML = '<img id=imghead>'; var img = document.getElementById('imghead'); img.filters.item('DXImageTransform.Microsoft.AlphaImageLoader').src = src; var rect = clacImgZoomParam(MAXWIDTH, MAXHEIGHT, img.offsetWidth, img.offsetHeight); status =('rect:'+rect.top+','+rect.left+','+rect.width+','+rect.height); div.innerHTML = "<div id=divhead style='width:"+rect.width+"px;height:"+rect.height+"px;margin-top:"+rect.top+"px;margin-left:"+rect.left+"px;"+sFilter+src+"\"'></div>"; } } function clacImgZoomParam( maxWidth, maxHeight, width, height ){ var param = {top:0, left:0, width:width, height:height}; if( width>maxWidth || height>maxHeight ) { rateWidth = width / maxWidth; rateHeight = height / maxHeight; if( rateWidth > rateHeight ) { param.width = maxWidth; param.height = Math.round(height / rateWidth); }else { param.width = Math.round(width / rateHeight); param.height = maxHeight; } } param.left = Math.round((maxWidth - param.width) / 2); param.top = Math.round((maxHeight - param.height) / 2); return param; } </script> </head> <body> <div id="preview"> <img id="imghead" width="100" height="100" border="0" src='../images/demo.jpg'><!--无预览时的默认图像,自己弄一个--> </div> <br/> <input type="file" onchange="previewImage(this)" /> </body> </html>
相关文章推荐
- 图片上传,支持同步/异步、预览(MVC、uploadify异步提交、js预览、ajaxSubmit异步提交)兼容大部分浏览器,含代码
- 上传时获取文件的完整路径图片预览的js代码(兼容Firfox和IE)
- 兼容好的JS图片上传预览代码
- js上传图片预览功能代码,兼容IE,FireFox,Chrome浏览器
- [转]很简单的JS实现上传前预览图片(兼容IE8)
- JS上传图片预览 兼容IE8 FireFox
- 基于asp.net + easyui框架,js实现上传图片之前判断图片格式,同时实现预览,兼容各种浏览器+下载
- 几种兼容IE和火狐 图片预览的JS代码
- 在页面预览客户端本地图片的js代码(兼容FF IE)
- 图片上传之前检查大小、尺寸、格式并预览的js代码
- js实现文件上传,图片本地预览(部分代码是借鉴的)
- js :实现图片上传前,预览客户端图片(兼容IE6和IE7)
- JS 预览上传图片,兼容IE、firefox等所有浏览器
- JS实现兼容IE6、IE7、IE8的图片上传前预览效果
- 来之不易的js图片上传预览代码
- 支持firefox10和IE的上传预览图片js代码
- 兼容IE6,IE7的JS图片预览代码
- 图片上传之前检查大小、尺寸、格式并预览的js代码
- 基于asp.net + easyui框架,js实现上传图片之前判断图片格式,同时实现预览,兼容各种浏览器+下载
- js实现图片上传及预览---------------------->>兼容ie6-8 火狐以及谷歌