zoukankan      html  css  js  c++  java
  • FileReader与URL.createObjectURL实现图片、视频上传前预览

    之前做图片、视频上传预览常用的方案是先把文件上传到服务器,等服务器返回文件的地址后,再把该地址字符串赋给img或video的src属性,这才实现所谓的文件预览。实际上这只是文件“上传后再预览”,这既浪费了用户的时间,也浪费了不可轻视的流量。

    最近上网查资料才知道其实可以很轻松地实现“上传前预览”。实现方法有两种:FileReader和URL.createObjectURL。

    关于FileReader的讲解可以看这里

    关于URL.createObjectURL方法的讲解和应用可以看这里

    demo地址

    直接上代码:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>preview</title>
        <style>
            * {
                box-sizing: border-box;
            }
            .section {
                margin: 20px auto;
                 500px;
                border: 1px solid #666;
                text-align: center;
            }
            .preview {
                 100%;
                margin-top: 10px;
                padding: 10px;
                min-height: 100px;
                background-color: #999;
            }
            .preview img,
            .preview video {
                 100%;
            }
        </style>
        <script src="https://cdn.staticfile.org/jquery/3.2.1/jquery.min.js" type="text/javascript"></script>
    </head>
    <body>
        <div class="section">
            <p>方案1</p>
            <input class="upload" type="file" onchange=onUpload1(this.files[0])>
            <div class="preview preview1"></div>
        </div>
    
        <div class="section">
            <p>方案2</p>
            <input class="upload" type="file" onchange=onUpload2(this.files[0])>
            <div class="preview preview2"></div>
        </div>
        <script>
            function onUpload1 (file) {
                var fr = new FileReader();
                fr.readAsDataURL(file);  // 将文件读取为Data URL
    
                fr.onload = function(e) {
                    var result = e.target.result;
                    if (/image/g.test(file.type)) {
                        var img = $('<img src="' + result + '">');
                        $('.preview1').html('').append(img);
                    } else if (/video/g.test(file.type)) {
                        var vidoe = $('<video controls src="' + result + '">');
                        $('.preview1').html('').append(vidoe);
                    }
                }
            }
    
            function onUpload2 (file) {
                var blob = new Blob([file]), // 文件转化成二进制文件
                    url = URL.createObjectURL(blob); //转化成url
                if (/image/g.test(file.type)) {
                    var img = $('<img src="' + url + '">');
                    img[0].onload = function(e) {
                        URL.revokeObjectURL(this.src);  // 释放createObjectURL创建的对象
                    }
                    $('.preview2').html('').append(img);
                } else if (/video/g.test(file.type)) {
                    var video = $('<video controls src="' + url + '">');
                    $('.preview2').html('').append(video);
                    video[0].onload = function(e) {
                        URL.revokeObjectURL(this.src);  // 释放createObjectURL创建的对象
                    }
                }
            }
        </script>
    </body>
    </html>复制代码

    demo截图:

    方案1、2 上传图片方案1、2 上传图片
    方案1 上传视频方案1 上传视频
    方案2 上传视频方案2 上传视频

    可以看出FileReader和URL.createObjectURL都能完美的实现图片的预览,但对于视频的上传,FileReader就不行了,浏览器立马崩溃了。。。,然而URL.createObjectURL方法却完美实现。

    关于二者的具体区别在网上一时没查清楚,但总体感觉URL.createObjectURL比FileReader性能更好一些。有什么说错的地方还望指正。

  • 相关阅读:
    每日英语:5 Ways the World Will Change Radically This Century
    每日英语:Foreign Visits Rise Amid Europe's Downturn
    vs2010和Matlab R2011b 混合编程的配置
    每日英语:Hon Hai Riot Underlines Rising Tensions in Chinese Factories
    优雅的实现对外接口,要注意哪些问题?
    一文搞定关系数据库设计要领,值得收藏!
    面试官:如果要存 IP 地址,用什么数据类型比较好?
    卧槽!IDEA 写代码防沉迷了?
    面试官:Minor GC、Major GC、Full GC 区别?我竟然答不上来。。
    Spring Boot + Vue + Shiro 实现前后端分离、权限控制
  • 原文地址:https://www.cnblogs.com/xzybk/p/11771990.html
Copyright © 2011-2022 走看看