本地图片预览(支持IE6/IE7/IE8/Firefox3)经验总结


Posted in Javascript onMarch 25, 2013

最近在Web项目开发过程中遇到的本地图片预览的需求,虽然最后因为其他原因没能使用,但是也算有些了解,整理出来。

这里我们按浏览器分,主要包括IE6,IE7/8 和Firefox3, 不包含Opera,Safari和Chrome,这三个基本上需求很小,没有研究。

总结一下就是
IE6下可以直接从file的value获取图片路径来显示预览。
IE7和IE8下通过select获取file的图片路径,再用滤镜来显示预览。
FireFox下调用file的getAsDataURL方法获取Data URI数据来显示预览。

下面是一个完整的Demo:

<html> 
<head> 
<script src="http://deepliquid.com/projects/Jcrop/js/jquery.min.js"></script> 
</head> 
<body> 
<input type="file" id="picture" name="picture" size="35" value="" onchange="setImg(this)"/> 
<div id="preview_fake" style="margin-left: 50px"> 
</div> 
<img id="preview_size_fake"/> 
<style type="text/css"> 
#preview_fake{ 
/* 该对象用于在IE下显示预览图片 
*/ 
filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale); 
} 
#preview_size_fake{ 
/* 该对象只用来在IE下获得图片的原始尺寸,无其它用途 
*/ 
filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=image); 
visibility:hidden; 
} 
</style> 
<script type="text/javascript"> 
function setImg(obj){ 
if( !obj.value.match( /.jpg|.gif|.png|.bmp/i ) ){ 
alert('图片格式无效!'); 
return false; 
} 
$("#preview_fake").empty(); 
var img = document.createElement("img"); 
img.setAttribute("src", ""); 
img.setAttribute("id", "preview"); 
document.getElementById("preview_fake").appendChild(img); 
if($.browser.msie){ 
if($.browser.version == 6.0){ 
$("#preview").attr("src",obj.value); 
}else{ 
var objPreview = document.getElementById('preview' ); 
var objPreviewFake = document.getElementById('preview_fake' ); 
var objPreviewSizeFake = document.getElementById('preview_size_fake' ); 
obj.select(); 
var imgSrc =document.selection.createRange().text; 
objPreviewFake.filters.item('DXImageTransform.Microsoft.AlphaImageLoader').src= imgSrc; 
objPreviewSizeFake.filters.item('DXImageTransform.Microsoft.AlphaImageLoader').src= imgSrc; 
autoSizePreview(objPreviewFake,objPreviewSizeFake.offsetWidth,objPreviewSizeFake.offsetHeight ); 
objPreview.style.display ='none'; 
} 
} 
if($.browser.mozilla){ 
$("#preview").attr("src",obj.files[0].getAsDataURL()); 
} 
if($.browser.opera){ 
alert("暂时不支持Opera浏览器"); 
} 
if($.browser.safari){ 
alert("暂时不支持Safari浏览器"); 
} 
} 
</script> 
</body> 
</html>
Javascript 相关文章推荐
让textarea控件的滚动条怎是位与最下方
Apr 20 Javascript
JS遮罩层效果 兼容ie firefox jQuery遮罩层
Jul 26 Javascript
javascript中的window.location.search方法简介
Sep 02 Javascript
JavaScript实现删除,移动和复制文件的方法
Aug 05 Javascript
原生JS实现首页进度加载动画
Sep 14 Javascript
Vue.js路由组件vue-router使用方法详解
Dec 02 Javascript
jquery+html仿翻页相册功能
Dec 20 Javascript
Angular2实现组件交互的方法分析
Dec 19 Javascript
zTree 树插件实现全国五级地区点击后加载的示例
Feb 05 Javascript
React学习笔记之高阶组件应用
Jun 02 Javascript
JS函数基本定义与用法示例
Jan 15 Javascript
vue项目中使用vue-layer弹框插件的方法
Mar 11 Javascript
JS上传前预览图片实例
Mar 25 #Javascript
js实现杯子倒水问题自动求解程序
Mar 25 #Javascript
js实现上传图片之上传前预览图片
Mar 25 #Javascript
使用jQuery validate 验证注册表单实例演示
Mar 25 #Javascript
多个表单中如何获得这个文件上传的网址实现js代码
Mar 25 #Javascript
jquery中使用$(#form).submit()重写提交表单无效原因分析及解决
Mar 25 #Javascript
博客侧边栏模块跟随滚动条滑动固定效果的实现方法(js+jquery等)
Mar 24 #Javascript
You might like
php仿ZOL分页类代码
2008/10/02 PHP
PHP大批量数据操作时临时调整内存与执行时间的方法
2011/04/20 PHP
PHP的5个安全措施小结
2012/07/17 PHP
ThinkPHP实现分页功能
2017/04/28 PHP
在Ubuntu 18.04上安装PHP 7.3 7.2和7.0的方法
2019/04/09 PHP
JavaScript之appendChild、insertBefore和insertAfter使用说明
2010/12/30 Javascript
用jQuery模拟select下拉框的简单示例代码
2014/01/26 Javascript
BootStrap日期控件在模态框中选择时间下拉菜单无效的原因及解决办法(火狐下不能点击)
2016/08/18 Javascript
jQuery动态生成表格及右键菜单功能示例
2017/01/13 Javascript
进阶之初探nodeJS
2017/01/24 NodeJs
Avalonjs双向数据绑定与监听的实例代码
2017/06/23 Javascript
JS排序算法之希尔排序与快速排序实现方法
2017/12/12 Javascript
自定义PC微信扫码登录样式写法
2017/12/12 Javascript
jQuery UI实现动画效果代码分享
2018/08/19 jQuery
vue-cli 3.x 配置Axios(proxyTable)跨域代理方法
2018/09/19 Javascript
微信小程序wxs实现吸顶效果
2020/01/08 Javascript
vue+canvas实现拼图小游戏
2020/09/18 Javascript
python 示例分享---逻辑推理编程解决八皇后
2014/07/20 Python
在Python下使用Txt2Html实现网页过滤代理的教程
2015/04/11 Python
Python通过命令开启http.server服务器的方法
2017/11/04 Python
windows下pycharm安装、创建文件、配置默认模板
2018/07/31 Python
Python脚本如何在bilibili中查找弹幕发送者
2020/06/04 Python
scrapy利用selenium爬取豆瓣阅读的全步骤
2020/09/20 Python
Python基于execjs运行js过程解析
2020/11/27 Python
学生的自我鉴定范文
2013/10/24 职场文书
体育教育专业毕业生自荐信
2013/11/15 职场文书
运动会通讯稿100字
2014/01/31 职场文书
政治学求职信
2014/06/03 职场文书
小学领导班子对照材料
2014/08/23 职场文书
2014国庆65周年领导讲话稿(3篇)
2014/09/21 职场文书
灵山大佛导游词
2015/02/04 职场文书
详解python字符串驻留技术
2021/05/21 Python
Django分页器的用法你都了解吗
2021/05/26 Python
Python面试不修改数组找出重复的数字
2022/05/20 Python
vue3不同环境下实现配置代理
2022/05/25 Vue.js
Android RecyclerView实现九宫格效果
2022/06/28 Java/Android