简体   繁体   English

图片转Base64

[英]Image convert to Base64

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

I would like to get the image in base64 once the user chose that (before submitting the form)一旦用户选择(在提交表单之前),我想在base64中获取图像

Something like :就像是 :

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

I read about File API and other stuffs, I would like a simple and cross-browsers solution (IE6/IE7 excluded obviously)我阅读了有关文件 API 和其他内容的信息,我想要一个简单的跨浏览器解决方案(显然不包括 IE6/IE7)

Any help appreciated thanks.任何帮助表示感谢。

 function readFile() { if (!this.files || !this.files[0]) return; const FR = new FileReader(); FR.addEventListener("load", function(evt) { document.querySelector("#img").src = evt.target.result; document.querySelector("#b64").textContent = evt.target.result; }); FR.readAsDataURL(this.files[0]); } document.querySelector("#inp").addEventListener("change", readFile);
 <input id="inp" type="file"> <p id="b64"></p> <img id="img" height="150">

( PS: A base64 encoded image (String) 4/3 the size of the original image data) PS:一张base64编码的图片(String)是原始图片数据大小的4/3)

Check this answer for multiple images upload . 检查此答案以获取多张图片上传

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

Exactly what you need:) You can choose callback version or Promise version.正是您需要的:)您可以选择回调版本或承诺版本。 Note that promises will work in IE only with Promise polyfill lib.You can put this code once on a page, and this function will appear in all your files.请注意,promise 只能在 IE 中使用 Promise polyfill lib。您可以将此代码放在页面上一次,此功能将出现在您的所有文件中。

The loadend event is fired when progress has stopped on the loading of a resource (eg after "error", "abort", or "load" have been dispatched) loadend 事件在资源加载停止时触发(例如,在“error”、“abort”或“load”已被调度之后)

Callback version回调版本

        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 version承诺版

    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 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);
}

It's useful to work with Deferred Object in this case, and return promise:在这种情况下使用Deferred Object很有用,并返回 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();
}

And above function could be used in this way:上面的函数可以这样使用:

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

Or in your case:或者在你的情况下:

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

Function convert image to base64 using jquery (you can convert to vanila js).使用 jquery 将图像转换为 base64 的函数(您可以转换为 vanila js)。 Hope it help to you!希望对你有帮助!

Usage: input is your nameId input has file image用法:输入是你的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>

Example: converImageToBase64('yourFileInputId')示例:converImageToBase64('yourFileInputId')

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

 // 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密码箱

For modern Browsers (no IE support)对于现代浏览器(不支持 IE)

Html file input 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 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;
  });
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM