zoukankan      html  css  js  c++  java
  • 兼容IE firefox 的图片上传预览

    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">       
    <head>       
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />       
    <title>Firefox3,IE6,IE7,IE8上传图片预览</title>       
    <style type="text/css"><!--  
          
    #preview_wrapper{        
        display:inline-block;        
        300px;        
        height:300px;        
        background-color:#CCC;        
    }        
    #preview_fake{ /* 该对象用户在IE下显示预览图片 */        
        filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale);        
    }        
    #preview_size_fake{ /* 该对象只用来在IE下获得图片的原始尺寸,无其它用途 */        
        filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=image);          
        visibility:hidden;        
    }        
    #preview{ /* 该对象用户在FF下显示预览图片 */        
        300px;        
        height:300px;        
    }        
    --></style><style type="text/css" mce_bogus="1">       
    #preview_wrapper{        
        display:inline-block;        
        300px;        
        height:300px;        
        background-color:#CCC;        
    }        
    #preview_fake{ /* 该对象用户在IE下显示预览图片 */        
        filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale);        
    }        
    #preview_size_fake{ /* 该对象只用来在IE下获得图片的原始尺寸,无其它用途 */        
        filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=image);          
        visibility:hidden;        
    }        
    #preview{ /* 该对象用户在FF下显示预览图片 */        
        300px;        
        height:300px;        
    }      </style>       
           
    <script type="text/javascript"><!--  
           
    function onUploadImgChange(sender){        
        if( !sender.value.match( /.jpg|.gif|.png|.bmp/i ) ){        
            alert('图片格式无效!');        
            return false;        
        }        
                
        var objPreview = document.getElementById( 'preview' );        
        var objPreviewFake = document.getElementById( 'preview_fake' );        
        var objPreviewSizeFake = document.getElementById( 'preview_size_fake' );        
                
        if( sender.files &&  sender.files[0] ){        
            objPreview.style.display = 'block';        
            objPreview.style.width = 'auto';        
            objPreview.style.height = 'auto';        
                    
            // Firefox 3 请使用此代码    
            //objPreview.src = sender.files[0].getAsDataURL();
           //firefox 8 请使用此代码
           // objPreview.src = window.URL.createObjectURL(sender.files[0]);        
            //chrome 请使用此代码    
            //objPreview.src = window.webkitURL.createObjectURL(sender.files[0]);            
            if (sender.files[0].getAsDataURL) objPreview.src = sender.files[0].getAsDataURL();
            if (window.URL.createObjectURL) objPreview.src = window.URL.createObjectURL(sender.files[0]);
            if (window.webkitURL.createObjectURL) objPreview.src = window.webkitURL.createObjectURL(sender.files[0]);
            if (window.createObjectURL) objPreview.src = window.createObjectURL(sender.files[0]);
            //实例化file reader对象
    //        var img = new Image();
    //        var reader = new FileReader();
    //        reader.onload = function (e) {
    //            img.src = this.result; // e.target.result
    //           // oDragWrap.appendChild(img);
    //        }
    //        reader.readAsDataURL(sender.files[0]);
        }else if( objPreviewFake.filters ){         
            // IE7,IE8 在设置本地图片地址为 img.src 时出现莫名其妙的后果        
            //(相同环境有时能显示,有时不显示),因此只能用滤镜来解决        
            sender.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';
        }
        //sender.blur();    
    }        
           
    function onPreviewLoad(sender){        
        autoSizePreview( sender, sender.offsetWidth, sender.offsetHeight );        
    }        
           
    function autoSizePreview( objPre, originalWidth, originalHeight ){        
        var zoomParam = clacImgZoomParam( 300, 300, originalWidth, originalHeight );        
        objPre.style.width = zoomParam.width + 'px';        
        objPre.style.height = zoomParam.height + 'px';        
        objPre.style.marginTop = zoomParam.top + 'px';        
        objPre.style.marginLeft = zoomParam.left + 'px';        
    }        
           
    function clacImgZoomParam( maxWidth, maxHeight, width, height ){        
        var param = { width, height:height, top:0, left:0 };        
                
        if( width>maxWidth || height>maxHeight ){        
            rateWidth = width / maxWidth;        
            rateHeight = height / maxHeight;        
                    
            if( rateWidth > rateHeight ){        
                param.width =  maxWidth;        
                param.height = height / rateWidth;        
            }else{        
                param.width = width / rateHeight;        
                param.height = maxHeight;        
            }        
        }        
                
        param.left = (maxWidth - param.width) / 2;        
        param.top = (maxHeight - param.height) / 2;        
                
        return param;        
    }        
    // --></script>       
           
    </head>       
           
    <body>       
        <div id="preview_wrapper">       
            <div id="preview_fake">       
                <img id="preview" src="data:image/gif;base64,R0lGODlhAQABAIAAAP///wAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==" onload="onPreviewLoad(this)"/>       
            </div>       
        </div>       
        <br/>       
        <input id="upload_img" type="file" onchange="onUploadImgChange(this)"/>       
        <br/>       
        <img id="preview_size_fake"/>       
    </body>       
    </html>     
  • 相关阅读:
    JavaWeb笔记:连接数据库
    Android笔记:ViewGroup
    Java笔记:异常
    Java笔记:文件夹操作
    Java笔记:有啥记啥
    Java笔记:Number
    Java笔记:修饰符
    数据仓库之启用cdc
    多线程之线程池任务管理通用模板
    关于RESTful 的使用(实战)
  • 原文地址:https://www.cnblogs.com/wzq806341010/p/2957638.html
Copyright © 2011-2022 走看看