zoukankan      html  css  js  c++  java
  • 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=" 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不行,但是获取焦点后同样解决了该问题

     

  • 相关阅读:
    合并两个有序列表
    根据前序遍历和中序遍历还原二叉树
    快速排序
    二叉树搜索的后序遍历序列
    最长回文子串
    爬楼梯
    Selenium EC 与 Wait
    爬取Django 绕过csrf实现批量注册
    Django 数据传递 个人汇总贴
    python bytes和str转换
  • 原文地址:https://www.cnblogs.com/wangx036/p/4779993.html
Copyright © 2011-2022 走看看