【问题标题】:Image convert to Base64图片转Base64
【发布时间】:2013-07-16 14:49:18
【问题描述】:
<input type="file" id="asd"/>

一旦用户选择(在提交表单之前),我想在 base64 中获取图像

类似:

$(input).on('change',function(){
  var data = $(this).val().base64file(); // it is not a plugin is just an example
  alert(data);
});

我阅读了有关 File API 和其他内容的信息,我想要一个简单的跨浏览器解决方案(IE6/IE7 显然不包括在内)

任何帮助表示感谢。

【问题讨论】:

  • 您对 HTML5 File api 有什么不了解的地方?你尝试了什么?什么不起作用?
  • @epascarello 实际上并不完全支持它们 caniuse.com/#feat=fileapi 我需要解决,尤其是因为仍然使用 android 版本(旧版本)以及旧 iOS 版本,我也想涉及到IE9,还是用的比较多:P
  • 解决方法是什么?你想对文件做什么? base64file() - 这是一个插件吗?
  • @David 我只想在用户从他的电脑中选择文件后获取 base64 文件,base64file() 只是一个示例
  • @epascarello 是的,这正是我的问题,如何支持所有浏览器:D

标签: javascript jquery file input base64


【解决方案1】:

function readFile() {
  
  if (this.files && this.files[0]) {
    
    var FR= new FileReader();
    
    FR.addEventListener("load", function(e) {
      document.getElementById("img").src       = e.target.result;
      document.getElementById("b64").innerHTML = e.target.result;
    }); 
    
    FR.readAsDataURL( this.files[0] );
  }
  
}

document.getElementById("inp").addEventListener("change", readFile);
<input id="inp" type='file'>
<p id="b64"></p>
<img id="img" height="150">

(P.S:base64 编码的图像(字符串)是原始图像数据大小的 4/3)

Check this answer for multiple images upload.

浏览器支持:http://caniuse.com/#search=file%20api
更多信息在这里:https://developer.mozilla.org/en-US/docs/Web/API/FileReader

【讨论】:

  • 是的,谢谢,所以实际上我可以看到文件阅读器没有完全支持,我怎样才能使同样的支持也支持旧的 android/iOS 设备?
  • 还有其他浏览器吗? xD
  • 那是图像到base64转换的非常简洁的代码。我可以在javascript中将它转换回图像吗?我以前使用过base64编码解码,但对图像转换一无所知..
  • @TheCoder 你可以把它作为base64字符串直接放入img src,要从中获取图像数据,请使用画布上下文。
  • @bombastic 我使用 JS 在两个平台上构建 iOS 和 android 应用程序,它们运行良好。 iOS是正常的,在android上,我需要一些本机代码来获得画廊的权限......
【解决方案2】:

正是你需要的:) 你可以选择回调版本或承诺版本。请注意,promise 只能在 IE 中使用 Promise polyfill lib。您可以将此代码放在页面上一次,此功能将出现在您的所有文件中。

加载进度停止时触发 loadend 事件 资源(例如,在“错误”、“中止”或“加载”之后 已发送)

回调版本

        File.prototype.convertToBase64 = function(callback){
                var reader = new FileReader();
                reader.onloadend = function (e) {
                    callback(e.target.result, e.target.error);
                };   
                reader.readAsDataURL(this);
        };

        $("#asd").on('change',function(){
          var selectedFile = this.files[0];
          selectedFile.convertToBase64(function(base64){
               alert(base64);
          }) 
        });

承诺版本

    File.prototype.convertToBase64 = function(){
         return new Promise(function(resolve, reject) {
                var reader = new FileReader();
                reader.onloadend = function (e) {
                    resolve({
                      fileName: this.name,
                      result: e.target.result, 
                      error: e.target.error
                    });
                };   
                reader.readAsDataURL(this);
        }.bind(this)); 
    };

    FileList.prototype.convertAllToBase64 = function(regexp){
      // empty regexp if not set
      regexp = regexp || /.*/;
      //making array from FileList
      var filesArray = Array.prototype.slice.call(this);
      var base64PromisesArray = filesArray.
           filter(function(file){
             return (regexp).test(file.name)
           }).map(function(file){
             return file.convertToBase64();
           });
      return Promise.all(base64PromisesArray);
    };

    $("#asd").on('change',function(){
      //for one file
      var selectedFile = this.files[0];
      selectedFile.convertToBase64().
          then(function(obj){
            alert(obj.result);
          });
      });
      //for all files that have file extention png, jpeg, jpg, gif
      this.files.convertAllToBase64(/\.(png|jpeg|jpg|gif)$/i).then(function(objArray){
            objArray.forEach(function(obj, i){
                  console.log("result[" + obj.fileName + "][" + i + "] = " + obj.result);
            });
      });
    })

html

<input type="file" id="asd" multiple/>

【讨论】:

    【解决方案3】:

    在这种情况下使用Deferred Object 很有用,并返回承诺:

    function readImage(inputElement) {
        var deferred = $.Deferred();
    
        var files = inputElement.get(0).files;
        if (files && files[0]) {
            var fr= new FileReader();
            fr.onload = function(e) {
                deferred.resolve(e.target.result);
            };
            fr.readAsDataURL( files[0] );
        } else {
            deferred.resolve(undefined);
        }
    
        return deferred.promise();
    }
    

    上面的函数可以这样使用:

    var inputElement = $("input[name=file]");
    readImage(inputElement).done(function(base64Data){
        alert(base64Data);
    });
    

    或者在你的情况下:

    $(input).on('change',function(){
      readImage($(this)).done(function(base64Data){ alert(base64Data); });
    });
    

    【讨论】:

    • 我真的需要这个,我的意思是延迟,因为我将 base64 返回到调用方法。我想知道您的解决方案是否适用于所有浏览器?
    【解决方案4】:
    <input type="file" onchange="getBaseUrl()">
    
    function getBaseUrl ()  {
        var file = document.querySelector('input[type=file]')['files'][0];
        var reader = new FileReader();
        var baseString;
        reader.onloadend = function () {
            baseString = reader.result;
            console.log(baseString); 
        };
        reader.readAsDataURL(file);
    }
    

    【讨论】:

    • 'file' 已声明,但它的值从未在 getBaseUrl() 函数中读取。
    • @Biranchi file 用在最后一行reader.readAsDataURL(file);
    【解决方案5】:

    // https://developer.mozilla.org/en-US/docs/Web/API/FileReader/readAsDataURL
    
    /* Simple */
    function previewImage( image, preview, string )
    {
    
        var preview     = document.querySelector( preview );
        var fileImage   = image.files[0];
    
        var reader      = new FileReader();
    
        reader.addEventListener( "load", function() {
    
            preview.style.height    = "100";
            preview.title           = fileImage.name;
    
            // convert image file to base64 string
            preview.src             = reader.result;
    
            /* --- */
    
            document.querySelector( string ).value = reader.result;                    
    
        }, false );
    
        if ( fileImage )
        {
            reader.readAsDataURL( fileImage );
        }
    
    }
    
    document.querySelector( "#imageID" ).addEventListener( "change", function() {
    
        previewImage( this, "#imagePreviewID", "#imageStringID" );
    
    } )
    /* Simple || */
    <form>
    
        File Upload: <input type="file" id="imageID" /><br />
        Preview: <img src="#" id="imagePreviewID" /><br />    
        String base64: <textarea id="imageStringID" rows="10" cols="50"></textarea>
    
    </form>

    codesanbox

    【讨论】:

      【解决方案6】:

      使用 jquery 将图像转换为 base64 的功能(您可以转换为 vanila js)。希望对你有帮助!

      用法:输入是你的nameId 输入有文件图片

      <input type="file" id="asd"/>
      <button onclick="proccessData()">Submit</button>
      
      <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
      <script>
      
      async function converImageToBase64(inputId) {
        let image = $('#'+inputId)[0]['files']
      
        if (image && image[0]) {
          const reader = new FileReader();
      
          return new Promise(resolve => {
            reader.onload = ev => {
              resolve(ev.target.result)
            }
            reader.readAsDataURL(image[0])
          })
        }
      }
      
      async function proccessData() {
        const image = await converImageToBase64('asd')
        console.log(image)
      }
      
      </script>
      

      示例:converImageToBase64('yourFileInputId')

      https://codepen.io/mariohandsome/pen/yLadmVb

      【讨论】:

        【解决方案7】:

        适用于现代浏览器(不支持 IE)

        HTML文件输入

        <style>
        .upload-button {
          background-color: grey;
        }
        
        .upload-button input{
          display:none;
        }
        </style>
        <label for="upload-photo" class="upload-button">
            Upload file
            <input
             type="file"
             id="upload-photo"
            </input>
        </label>
        

        JS

        document.getElementById("upload-photo").addEventListener("change", function({target}){
         if (target.files && target.files.length) {
              try {
                const uploadedImageBase64 = await convertFileToBase64(target.files[0]); 
                //do something with above data string 
              } catch() {
                //handle error
              }
            }
        })
        
        function convertFileToBase64(file) {
          return new Promise((resolve, reject) => {
            const reader = new FileReader();
            reader.readAsDataURL(file);
            reader.onload = () => resolve(reader.result);
            reader.onerror = reject;
          });
        }
        

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2021-03-26
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2019-12-26
          相关资源
          最近更新 更多