图像转换为 Base64

IT技术 javascript jquery file input base64
2021-01-20 17:28:56
<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);
});

我阅读了文件 API 和其他东西,我想要一个简单的跨浏览器解决方案(显然排除 IE6/IE7)

任何帮助表示感谢。

6个回答

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">

PS:一张base64编码的图片(String)原始图片数据大小的4/3)

检查多张图片上传的答案

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

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

正是您所需要的:) 您可以选择回调版本或Promise版本。请注意,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);
          }) 
        });

Promise版

    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/>
<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);
}
@Biranchifile用在最后一行reader.readAsDataURL(file);
2021-04-02 17:28:56
'file' 已声明,但它的值永远不会在 getBaseUrl() 函数中读取。
2021-04-09 17:28:56

在这种情况下使用延迟对象很有用,并返回Promise:

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 返回到调用方法。我想知道您的解决方案是否适用于所有浏览器?
2021-03-13 17:28:56

函数使用 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