基于jquery实现图片上传本地预览功能

1、原理javascript

  分为两步:css

  当上传图片的input被触发并选择本地图片以后获取要上传的图片这个对象的URL(对象URL),把对象URL赋值给事先写好的img标签的src属性便可把图片显示出来。在这里,咱们须要了解Javascript里File对象、Blob对象和window.URL.createObjectURL()方法。html

  一、File对象java

  File对象能够用来获取某个文件的信息,还能够用来读取这个文件的内容.一般状况下,File对象是来自用户在一个input元素上选择文件后返回的FileList对象,也能够是来自由拖放操做生成的 DataTransfer对象.下面来看获取FileList对象:jquery

<script type="text/javascript" src="jquery.js"></script>
<input id="upload" type="file">
<img id="preview" src="">
<script type="text/javascript">
    $('#upload').change(function () {
        // 获取FileList的第一个元素
        alert(document.getelementbyid('upload').files[0]);
    });
</script>

二、Blob对象chrome

  一个Blob对象就是一个包含有只读原始数据的类文件对象.Blob对象中的数据并不必定得是JavaScript中的原生形式.File接口基于Blob,继承了Blob的功能,而且扩展支持了用户计算机上的本地文件.咱们想要获得的对象URL实际上就是从Blob这个对象获取的,由于File的接口继承Blob。下面就来把Blob对象转换成URL:浏览器

<script type="text/javascript">
    var f = document.getelementbyid('upload').files[0];
    var src = window.URL.createObjectURL(f);
    document.getElementById('preview').src = src;
</script>

一个比较完整的实例

<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title>HTML5 Upload</title>
    <style type="text/css">
        #destination {
            filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(true, sizingMethod=scale);
        }
    </style>

    <!--<script type="text/javascript" src="http://code.jquery.com/jquery-1.8.2.min.js"></script>-->
    <script type="text/javascript" src="http://localhost/jQuery/jquery.js"></script>
    <script type="text/javascript">
        //处理file input加载的图片文件
        $(document).ready(function (e) {
//判断浏览器是否有FileReader接口
            if (typeof FileReader == 'undefined') {
                $("#destination").css({'background': 'none'}).html('亲,您的浏览器还不支持HTML5的FileReader接口,没法使用图片本地预览,请更新浏览器得到最好体验');
//若是浏览器是ie
                if ($.browser.msie === true) {
//ie6直接用file input的value值本地预览
                    if ($.browser.version == 6) {
                        $("#imgUpload").change(function (event) {
//ie6下怎么作图片格式判断?
                            var src = event.target.value;
//var src = document.selection.createRange().text; //选中后 selection对象就产生了 这个对象只适合ie
                            var img = '<img src="' + src + '" width="200px" height="200px" />';
                            $("#destination").empty().append(img);
                        });
                    }
//ie7,8使用滤镜本地预览
                    else if ($.browser.version == 7 || $.browser.version == 8) {
                        $("#imgUpload").change(function (event) {
                            $(event.target).select();
                            var src = document.selection.createRange().text;
                            var dom = document.getElementById('destination');
//使用滤镜 成功率高
                            dom.filters.item('DXImageTransform.Microsoft.AlphaImageLoader').src = src;
                            dom.innerHTML = '';
//使用和ie6相同的方式 设置src为绝对路径的方式 有些图片没法显示 效果没有使用滤镜好
                            /*var img = '<img src="'+src+'" width="200px" height="200px" />';
                             $("#destination").empty().append(img);*/
                        });
                    }
                }
//若是是不支持FileReader接口的低版本firefox 能够用getAsDataURL接口
                else if ($.browser.mozilla === true) {
                    $("#imgUpload").change(function (event) {
//firefox2.0没有event.target.files这个属性 就像ie6那样使用value值 可是firefox2.0不支持绝对路径嵌入图片 放弃firefox2.0
//firefox3.0开始具有event.target.files这个属性 而且开始支持getAsDataURL()这个接口 一直到firefox7.0结束 不过之后均可以用HTML5的FileReader接口了
                        if (event.target.files) {
//console.log(event.target.files);
                            for (var i = 0; i < event.target.files.length; i++) {
                                var img = '<img src="' + event.target.files.item(i).getAsDataURL() + '" width="200px" height="200px"/>';
                                $("#destination").empty().append(img);
                            }
                        }
                        else {
//console.log(event.target.value);
//$("#imgPreview").attr({'src':event.target.value});
                        }
                    });
                }
            }
            else {
// version 1
                /*$("#imgUpload").change(function(e){
                 var file = e.target.files[0];
                 var fReader = new FileReader();
                 //console.log(fReader);
                 //console.log(file);
                 fReader.onload=(function(var_file)
                 {
                 return function(e)
                 {
                 $("#imgPreview").attr({'src':e.target.result,'alt':var_file.name});
                 }
                 })(file);
                 fReader.readAsDataURL(file);
                 });*/

//单图上传 version 2
                /*$("#imgUpload").change(function(e){
                 var file = e.target.files[0];
                 var reader = new FileReader();
                 reader.onload = function(e){
                 //displayImage($('bd'),e.target.result);
                 //alert('load');
                 $("#imgPreview").attr({'src':e.target.result});
                 }
                 reader.readAsDataURL(file);
                 });*/
//多图上传 input file控件里指定multiple属性 e.target是dom类型
                $("#imgUpload").change(function (e) {
                    for (var i = 0; i < e.target.files.length; i++) {
                        var file = e.target.files.item(i);
//容许文件MIME类型 也能够在input标签中指定accept属性
//console.log(/^image/.*$/i.test(file.type));
                        if (!(/^image/.*$ / i.test(file.type)
                    ))
                        {
                            continue; //不是图片 就跳出这一次循环
                        }

//实例化FileReader API
                        var freader = new FileReader();
                        freader.readAsDataURL(file);
                        freader.onload = function (e) {
                            var img = '<img src="' + e.target.result + '" width="200px" height="200px"/>';
                            $("#destination").empty().append(img);
                        }
                    }
                });

//处理图片拖拽的代码
                var destDom = document.getElementById('destination');
                destDom.addEventListener('dragover', function (event) {
                    event.stopPropagation();
                    event.preventDefault();
                }, false);

                destDom.addEventListener('drop', function (event) {
                    event.stopPropagation();
                    event.preventDefault();
                    var img_file = event.dataTransfer.files.item(0); //获取拖拽过来的文件信息 暂时取一个
//console.log(event.dataTransfer.files.item(0).type);
                    if (!(/^image/.*$ /
                    .
                    test(img_file.type)
                    ))
                    {
                        alert('您还未拖拽任何图片过来,或者您拖拽的不是图片文件');
                        return false;
                    }
                    fReader = new FileReader();
                    fReader.readAsDataURL(img_file);
                    fReader.onload = function (event) {
                        destDom.innerHTML = '';
                        destDom.innerHTML = '<img src="' + event.target.result + '" width="200px" height="200px"/>';
                    };
                }, false);
            }
        });
    </script>
</head>

<body>
<input type="file" id="imgUpload" name="imgUpload" draggable="true" single/> <!--容许file控件接受的文件类型-->
<!--<input type="file" id="imgUpload" name="imgUpload" accept="image/*" multiple/>-->
<div id="destination" style="width:200px;height:200px;border:1px solid #000000;"><img src="nopic.jpg"/></div>
</body>
</html>

 

2、兼容性app

  上述方法适用于chrome浏览器dom

  若是是IE浏览器能够直接使用input的value来代替srcui

  网上查看资料有直接使用File对象的getAsDataURL()方法获取URL的,如今这个方法都已经废除,相似的还有getAsText()和getAsBinary()方法;

相关文章
相关标签/搜索