JavaScript图片上传前的图片预览功能

JS代码:

 1 //js本地图片预览,兼容ie[6-9]、火狐、Chrome17+、Opera11+、Maxthon3
 2 function PreviewImage(fileObj, imgPreviewId, divPreviewId) {
 3     var allowExtention = ".jpg,.bmp,.gif,.png"; //允许上传文件的后缀名document.getElementById("hfAllowPicSuffix").value;
 4     var extention = fileObj.value.substring(fileObj.value.lastIndexOf(".") + 1).toLowerCase();
 5     var browserVersion = window.navigator.userAgent.toUpperCase();
 6     if (allowExtention.indexOf(extention) > -1) {
 7         if (fileObj.files) { //HTML5实现预览,兼容chrome、火狐7+等
 8             if (window.FileReader) {
 9                 var reader = new FileReader();
10                 reader.onload = function(e) {
11                     document.getElementById(imgPreviewId).setAttribute("src", e.target.result);
12                 }
13                 reader.readAsDataURL(fileObj.files[0]);
14             } else if (browserVersion.indexOf("SAFARI") > -1) {
15                 alert("不支持Safari6.0以下浏览器的图片预览!");
16             }
17         } else if (browserVersion.indexOf("MSIE") > -1) {
18             if (browserVersion.indexOf("MSIE 6") > -1) { //ie6
19                 document.getElementById(imgPreviewId).setAttribute("src", fileObj.value);
20             } else { //ie[7-9]
21                 fileObj.select();
22                 if (browserVersion.indexOf("MSIE 9") > -1) {
23                     fileObj.blur(); //不加上document.selection.createRange().text在ie9会拒绝访问
24                 }
25                 var newPreview = document.getElementById(divPreviewId + "New");
26                 if (newPreview == null) {
27                     newPreview = document.createElement("div");
28                     newPreview.setAttribute("id", divPreviewId + "New");
29                     newPreview.style.width = document.getElementById(imgPreviewId).width + "px";
30                     newPreview.style.height = document.getElementById(imgPreviewId).height + "px";
31                     newPreview.style.border = "solid 1px #d2e2e2";
32                 }
33                 document.getElementById("divfocus").focus(); //解决document.selection.createRange()拒绝访问的问题
34                 newPreview.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=‘scale‘,src=‘" + document.selection.createRange().text + "‘)"; //document.selection.createRange().text
35                 var tempDivPreview = document.getElementById(divPreviewId);
36                 tempDivPreview.parentNode.insertBefore(newPreview, tempDivPreview);
37                 tempDivPreview.style.display = "none";
38
39             }
40         } else if (browserVersion.indexOf("FIREFOX") > -1) { //firefox
41             var firefoxVersion = parseFloat(browserVersion.toLowerCase().match(/firefox\/([\d.]+)/)[1]);
42             if (firefoxVersion < 7) { //firefox7以下版本
43                 document.getElementById(imgPreviewId).setAttribute("src", fileObj.files[0].getAsDataURL());
44             } else { //firefox7.0+
45                 document.getElementById(imgPreviewId).setAttribute("src", window.URL.createObjectURL(fileObj.files[0]));
46             }
47         } else {
48             document.getElementById(imgPreviewId).setAttribute("src", fileObj.value);
49         }
50     } else {
51         alert("仅支持" + allowExtention + "为后缀名的文件!");
52         fileObj.value = ""; //清空选中文件
53         if (browserVersion.indexOf("MSIE") > -1) {
54             fileObj.select();
55             document.selection.clear();
56         }
57         fileObj.outerHTML = fileObj.outerHTML;
58     }
59 }

前台页面:

1 <div style="width: 190px;" id="divfocus">
2      <div runat="server" id="divPreview" class="divProImg">
3          <img id="txImg" class="txImg" runat="server" onclick="upclick();" src="../skin/default/images/Default/undefined1.png" />
4      </div>
5      <asp:FileUpload ID="upLoadImage" runat="server" onchange="PreviewImage(this,‘cphContent_txImg‘,‘cphContent_divPreview‘)"
6          CssClass="fuhide" />
7      <input runat="server" id="txtImg" type="text" style="display: none" />
8 </div>

遇到问题:ie8及以下document.selection.createRange()拒绝访问,导致图片无法预览的问题

参考资料:http://blog.csdn.net/yiluoak_47/article/details/7869154

最近发现,在IE9下,公司网站的本地图片预览都无法正常显示,经过测试发现,原因在于IE9下无法获取file控件的文件路径。

以前的代码如下:

var strPic = fileImg.value;

if ($.ie && $.browser.version > 6) {
    fileImg.select();
    strPic = document.selection.createRange().text;
    document.selection.empty();

}

如果strPic不为空,则使用滤镜预览。

以上代码在IE 6 7 8均正常使用,在IE9下,document.selection.createRange()拒绝访问,看来安全性有所提高。

最后测试发现,在IE9下,如果file控件获得焦点,则document.selection.createRange()拒绝访问,

因此,只需要在fileImg.select()后面加一句fileImg.blur()即可。

但是,如果当前页面被嵌在框架中,则fileImg.blur()之后,file控件中原本被选中的文本将会失去选中的状态,因此,不能使用fileImg.blur()。

可以让当前页面上的其他元素,如div,button等获得焦点即可,如div_view.focus()。

注意,如果是div,则要确保div有至少1像素的高和宽,方可获得焦点。

目前在IE9中测试,一切正常。

解决方案:如上,虽然我的是ie9能正常使用,ie78不行,但是获取焦点后同样解决了该问题

时间: 2024-09-30 20:06:54

JavaScript图片上传前的图片预览功能的相关文章

html + js 实现图片上传,压缩,预览及图片压缩后得到Blob对象继续上传问题

先上效果 上传图片后(设置了最多上传3张图片,三张后上传按钮消失) 点击图片放大,可以使用删除和旋转按钮 (旋转功能主要是因为ios手机拍照后上传会有写图片被自动旋转,通过旋转功能可以调正) html页面 需要引入weui.min.css 不然没法渲染样式, 将下面的代码放在需要上传文件的地方就行了,如果不需要图片旋转功能, 可以直接删掉那个div, 改不改js无影响 addPhoto.html <!--图片缩略图--> <div class="weui-cells weui-

&lt;input type=&quot;file&quot;&gt;图片上传时,先预览

<label> <input type="file" id="upload"> </label> js $("#upload").on('change',function(){ var file = this.files[0]; console.log(this.files); var reader = new FileReader(); //读取文件过程方法 reader.onloadstart = func

html之file标签 --- 图片上传前预览 -- FileReader

记得以前做网站时,曾经需要实现一个图片上传到服务器前,先预览的功能.当时用html的<input type="file"/>标签一直实现不了,最后舍弃了这个标签,使用了其他方式来实现了这个功能. 今天无意发现了一个知识点,用html的file标签就能实现图片上传前预览,感觉很棒,记录一下!就是通过file标签和js的FileReader接口,把选择的图片文件调用readAsDataURL方法,把图片数据转成base64字符串形式显示在页面上. 1.闲话少说,测试一下,图片上

[转]html之file标签 --- 图片上传前预览 -- FileReader

记得以前做网站时,曾经需要实现一个图片上传到服务器前,先预览的功能.当时用html的<input type="file"/>标签一直实现不了,最后舍弃了这个标签,使用了其他方式来实现了这个功能. 今天无意发现了一个知识点,用html的file标签就能实现图片上传前预览,感觉很棒,记录一下!就是通过file标签和js的FileReader接口,把选择的图片文件调用readAsDataURL方法,把图片数据转成base64字符串形式显示在页面上. 1.闲话少说,测试一下,图片上

input file实现多选,限制文件上传类型,图片上传前预览功能

限制上传类型 & 多选:① accept 属性只能与 <input type="file" /> 配合使用.它规定能够通过文件上传进行提交的文件类型. ② multiple 属性规定输入字段可选择多个值. 示例: <!-- image/* 所有图片 image/png png图片 image/jpg jpg图片 image/gif gir动图 application/msword Word文档(.doc) application/vnd.openxmlform

HTML5 FileReader实现图片上传前预览

如果你的浏览器支持Html5的FileReader的话,实现图片上传前进行预览是一件非常容易之事情. 在控制器,创建一个视图Action: jQuery代码: 实时演示一下:

基于layUI的图片上传前预览功能的2种实现方式

上传页面采用了layui 的上传模块,要实现的功能:选择文件后---点击文件名,页面中间弹窗内预览图片,先看效果图: 预览功能的实现具体有2种方式:第一种是用blob+FileReader,第二种是layUI自带的. 1. 用layUI 自带的参数实现图片预览: layui.use('upload', function(){ ... choose: function(obj){ var files = this.files = obj.pushFile(); //将每次选择的文件追加到文件队列

html5 图片上传,支持图片预览、压缩、及进度显示,兼容IE6+及标准浏览器

原文:html5 图片上传,支持图片预览.压缩.及进度显示,兼容IE6+及标准浏览器 以前写过上传组件,见 打造 html5 文件上传组件,实现进度显示及拖拽上传,兼容IE6+及其它标准浏览器,对付一般的上传没有问题,不过如果是上传图片,且需要预览的话,就力有不逮了,趁着闲暇时间,给上传组件添加了单独的图片上传UI,支持图片预览和缩放(通过调整图片的大小以实现图片压缩). 上传组件特点 轻量级,不依赖任何JS库,核心代码(Q.Uploader.js)仅约700行,min版本加起来不到12KB 纯

图片上传时获取图片的宽和高

经常会遇到图片上传的问题,这时候我们会传图片的地址,宽和高到服务器,至于图片上传就不说了,这里主要说图片上传时获取图片的原始宽和高的问题. 一般而言,我们把图片上传至服务器时,服务器会返回一个上传地址给我们,这个就是我们图片的url了,但是光有这个还是不够的,因为还要将图片的宽和高传给服务器,这时候就可以这样做了.直接上代码: var img = new Image() img.src = url 然后就可以使用img.width和img.height来获取图片的宽和高了.当然仅仅这样做是不够的